Jira Connector
Documentation
Version: 9
Documentation

Jira Connector - Source Code


<ApiConfig Name="Jira"
           Slug="jira-connector"
           Version="9"
		   EngineVersion="16"
           Id="288c083b-6edb-4705-851b-80ecd6357347"
           Desc="Jira Connector can be used to integrate Jira and your defined data source, e.g. Microsoft SQL, Oracle, Excel, Power BI, etc. Get, write, delete Issues, Users, Worklogs, Comments just in a few clicks!"
           Logo=""
           >

  <VersionHistory>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Create new issue with Labels fails (Its not treated as Raw fragment)</Change>
	<Change Ver="9" Date="2024-10-03" Type="New">Allow to use Formatted Comment (Raw JSON) in create_worklog or update_worklog operations</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Add Environment and EnvironmentFormatted columns (Environment was null in Get Issues)</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Change BodyContentText, Description, Comment datatype to DT_NTEXT from DT_WSTR in get_issues and get_worklogs endpoints to allow larger tahn 2000 chars in ETL tools like SSIS</Change>
	<Change Ver="9" Date="2024-10-03" Type="New">Change Environment datatype to DT_NTEXT from DT_WSTR in create_issues and update_issues endpoints to allow larger tahn 2000 chars in ETL tools like SSIS</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Change Labels to DT_WSTR rather than DT_NTEXT in get_issues endpoint</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Allow to Update/Insert formatted values for Custom Paragraph (TextArea) Field (e.g. DescriptionFormatted)</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Add new AggregateProgressPercent feild in get_issues endpoint.</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Clicking on [Show Advanced Parameters] checkbox throws error for Fields table / endpoint - Invalid ConnectionString format.</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Change Custom Paragraph fields (e.g. Long Summary) to DT_NTEXT (more than 2000 chars) so ETL tools like SSIS works fine for longer string.</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Encode value used for textarea field INSERT / UPDATE (i.e. Description) - If you include double quote, new line, tab, slash etc in value error parsing JSON.</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Improve Speed for metadata fetch (added UseRawCache to avoid multiple API calls).</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">Some fields like DueDate detected as datetime (i.e. DT_DATE) rather than date (i.e. DT_DBDATE - without time part). DT_DATE can return date and time both. Use DT_DBDATE if field should just return date (no time part)</Change>
    <Change Ver="9" Date="2024-10-03" Type="Fix">BREAKING: Improve Speed by reducing number of unused columns from the output (e.g. customfields_value only needed for option fields, customfields_values only needed for array fields, customfields_text only needed for paragraph fields). After this change some of the unsed columns from your ETL Mappings / Reporting tools may be removed or throw error about column is missing, just ignore that warning / error becuase these unwanted columns were always set as null. Refresh your metadata and you will see number of custom field columns reduced drastically from you mappings.</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Allow to Update/Insert raw values for Custom Paragraph (TextArea) Field (e.g. set customfield_1234_text = 'your long description').</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Allow to Update/Insert raw values for Custom Option / Array / User / Team Field (e.g. Radio / Checkboxes / List Multiselect). (e.g. set customfield_1234 = '[{"value":"AA"}, {"value":"BB"}]').</Change>
    <Change Ver="9" Date="2024-10-03" Type="New">Allow to Update/Insert value for Custom Option Field (Dropdown / Radio) by value or option id. To update by Option entry id use customfield_nnnnn_value='BBB' and to update by id  customfield_nnnnn_id = '100023').</Change>
 
    <Change Date="2024-07-12" Type="New">Add option to Continue on 404 Error (Record not found) on UPDATE / DELETE operations</Change>
    <Change Date="2024-07-12" Type="New">Updated many examples</Change>
    <Change Date="2024-07-12" Type="New">Add JQL Parameter examples and dropdown options</Change>
    <Change Date="2024-07-12" Type="Fix">Added support for Id field in WHERE clause for SELECT / DELETE / UPDATE operations (now you can call FROM YourTable WHERE Id=1234).</Change>
    <Change Date="2024-07-12" Type="Fix">Some fields (e.g. Summary) are too small for ETL tools like SSIS.</Change>
    <Change Date="2024-04-25" Type="New">Added option to use PAT (Personal Access Token) for Authentication rather than userid / password.</Change>
    <Change Date="2024-04-19" Type="New">Added option to choose custom domain in service URL.</Change>
    <Change Date="2023-07-13" Type="New">Custom fields not listed correctly after you select them.</Change>
    <Change Date="2023-05-23" Type="New">Added support for OAuth.</Change>
    <Change Date="2023-05-23" Type="New">Added Lookup Support for Issues so now you can search by many Keys.</Change>
    <Change Date="2023-05-23" Type="New">Improved speed by changing maxResults to 100 and use PagingMaxRowsExpr to detect total rows (one less request in pagination).</Change>
    <Change Date="2022-05-02" Type="New">Added new endpoints get_custom_fields, get_custom_field_contexts and get_custom_field_option_for_context.</Change>
    <Change Date="2022-02-28" Type="New">Added new endpoints get_changelogs, get_changelog_details and get_changelogs_by_ids.</Change>
    <Change Date="2022-02-28" Type="New">Updated the Issue table [WorkRatio] column data type to String as it contains long number value (e.g.9117xxxxxxxxxxx2983).</Change>
    <Change Date="2022-02-21" Type="New">Added customfield value support for single / multi value fields. For multi select you can see comma separated values now.</Change>
    <Change Date="2021-03-29">Initial version</Change>
  </VersionHistory>

  <ServiceUrls>
    <ServiceUrl Name="V3" Url="https://[$Subdomain$].atlassian.net/rest/api/3" />
	<ServiceUrl Name="V3 (custom domain)" Url="https://something.mycompany.com/rest/api/3" Desc="If you added custom domain then enter domain and API URL here (V3 recommended)"/>	

    <ServiceUrl Name="V2 Legacy - Some Operations wont work" Url="https://[$Subdomain$].atlassian.net/rest/api/2" />
	<ServiceUrl Name="V2 Legacy - Some Operations wont work" Url="https://something.mycompany.com/rest/api/2" Desc="If you added custom domain then enter domain and API URL here (V3 recommended)"/>	

    
    <ServiceUrl Name="V3 OAuth" Url="https://api.atlassian.com/ex/jira/[$OrganizationId$]/rest/api/3" Desc="Example: https://api.atlassian.com/ex/jira/c6613685-699f-46dc-8013-f487134bc9fd/rest/api/3"/>
	
  </ServiceUrls>
  <Auths>
    <Auth Name="Http" Label="API Key based Authentication" Type="Http" ConnStr="CredentialType=Basic;" TestEndPoint="get_fields">
      <Params>
        <Param Name="Subdomain" Required="True" Label="Subdomain" Desc="Your company's Atlassian subdomain. Subdomain parameter is ignored this if you choose custom domain in service URL" />
        <Param Name="UserName"  Required="True" Label="Atlassian User Name (email)" HelpLink="" />
        <Param Name="Password"  Required="True" Label="API Key" HelpLink="https://id.atlassian.com/manage-profile/security/api-tokens" Secret="True" Desc="Get your API key by going to https://id.atlassian.com/manage-profile/security/api-tokens" />
        <Param Name="CustomColumnsRegex" Template="CustomColumnsRegexParam" />
      </Params>
      <Notes>
        <![CDATA[Firstly, login into your Atlassian account and then go to your Jira profile:
<p />
<ol>
  <li>Go to <a target="_blank" href="https://id.atlassian.com/manage-profile/security">Profile > Security</a>.</li>
  <li>Click <a target="_blank" href="https://id.atlassian.com/manage-profile/security/api-tokens">Create and manage API tokens</a>.</li>
  <li>Then click <b>Create API token</b> button and give your token a label.</li>
  <li>When window appears with new API token, copy and use it in this connection manager.</li>  
  <li>That's it!</li>  
</ol>
]]>
      </Notes>
    </Auth>
    <Auth Name="PAT" Label="Personal Access Token (PAT) Authentication" Type="Http" ConnStr="CredentialType=Token;" TestEndPoint="get_fields" HelpLink="https://confluence.atlassian.com/enterprise/using-personal-access-tokens-1026032365.html">
      <Params>
        <Param Name="Subdomain" Required="True" Label="Subdomain" Desc="Your company's Atlassian subdomain. Subdomain parameter is ignored this if you choose custom domain in service URL" />
        <Param Name="Password"  Required="True" Label="Token (PAT Bearer Token)" HelpLink="https://confluence.atlassian.com/enterprise/using-personal-access-tokens-1026032365.html" Secret="True" Desc="Get your Personal Access Token by following steps listed here https://confluence.atlassian.com/enterprise/using-personal-access-tokens-1026032365.html" />
        <Param Name="CustomColumnsRegex" Template="CustomColumnsRegexParam" />	
      </Params>
      <Notes>
        <![CDATA[Copy below URL and open in browser to see instructions about creating PAT (Personal Access Token) to access JIRA data using API.
<p />
https://confluence.atlassian.com/enterprise/using-personal-access-tokens-1026032365.html
]]>
      </Notes>
    </Auth>
	
    <Auth Type="OAuth" Name="oauth" Label="OAuth (**Must change API Base URL to V3 OAuth**)" Desc="OAuth App must be created in Atlassian Developer Console. It is found at https://developer.atlassian.com/console/myapps/"
      HelpLink="https://developer.atlassian.com/cloud/jira/platform/oauth-2-3lo-apps/"
      ConnStr="Provider=Custom;OAuthVersion=OAuth2;AuthUrl=https://auth.atlassian.com/authorize;TokenUrl=https://auth.atlassian.com/oauth/token;Scope=[$Scope$];ScopeSeparator={space};ContentType=application/json;ExtraAttributesForAuthRequest=audience=api.atlassian.com&amp;prompt=consent"
      TestEndPoint="get_fields">
      <Notes>
        <![CDATA[Firstly, login into your Atlassian account and then create Jira application:
<p />
<ol>
  <li>Go to <a target="_blank" href="https://developer.atlassian.com/console/myapps/">Atlassian Developer area.</a></li>
  <li>Click <a target="_blank" href="https://developer.atlassian.com/console/myapps/create-3lo-app/">Create app</a> and select <b>OAuth 2.0 (3LO) integration</b> app to create an OAuth app.</li>
  <li>Give your app a name, accept the terms and hit <b>Create</b>.</li>
  <li>Then hit <b>App details</b> panel and copy paste <i>Client ID</i> and <i>Secret</i> into the API Connection Manager configuration grid into the proper places.</li>
  <li>Then go back and click <b>Permissions</b> panel to enable permissions/scopes for your application. You can enable them all.</li>
  <li>Go back again to application settings and click <b>Authorization</b> panel.</li>
  <li>Click <b>Configure</b> button and in <b>Callback URL</b> enter your own Callback URL or simply enter <i>https://zappysys.com/oauth</i> if you don't have one.</li>
  <li>Use this same <i>Callback URL (Return URL)</i> in a API Connection Manager configuration grid.</li>
  <li>In <i>API Connection Manager</i> enter one or more of these scopes (<a target="_blank" href="https://developer.atlassian.com/cloud/jira/platform/scopes-for-connect-and-oauth-2-3LO-apps/#oauth-2-0-authorization-code-only-scopes">read more</a> about available scopes) into <b>Scopes</b> property:
      <ol>
          <li>offline_access <i>(a must)</i></li>
          <li>read:jira-user</li>
          <li>read:jira-work</li>
          <li>write:jira-work</li>
          <li>manage:jira-project</li>
          <li>manage:jira-configuration</li>
      </ol>
  </li>
  <li>Also configure your company's <b>Subdomain</b> in the properties grid.</li>
  <li>Click <b>Generate Token</b> to generate tokens.</li>   
  <li>That's it!</li>  
</ol>
]]>
      </Notes>
      <Params>
        <Param Name="ClientId" Required="True" />
        <Param Name="ClientSecret" Secret="True" Required="True"/>
        <Param Name="Scope"
               Required="True"
               Options="offline_access;read:jira-user;read:jira-work;write:jira-work;manage:jira-project;manage:jira-configuration;manage:jira-webhook"
               MultiSelectSeparator=" "
               MultiSelect="True"
               Value="offline_access~read:jira-user~read:jira-work~write:jira-work~manage:jira-project~manage:jira-configuration"
               Desc="Permissions you want to use."
               Example="offline_access read:jira-user read:jira-work write:jira-work manage:jira-project manage:jira-configuration manage:jira-webhook"
               HelpLink="https://developer.atlassian.com/cloud/jira/platform/scopes-for-connect-and-oauth-2-3LO-apps/#oauth-2-0-authorization-code-only-scopes"/>
        <Param Name="ReturnUrl" Value="https://zappysys.com/oauth"  Required="True"/>
		
		<Param Name="OrganizationId" OptionsEndPoint="get_resources"  OptionsEndPointValueColumn="Id" OptionsEndPointLabelColumn="Name" Required="True" Label="Organization Id (Select after clicking [Generate Token])" Desc="Your company's Alphanumeric ID (e.g. c66xxx-xxx-xxx). This is obtained by calling GET " />
        <Param Name="CustomColumnsRegex" Template="CustomColumnsRegexParam" Label="Custom Columns for output (Select after clicking [Generate Token])"/>		
      </Params>
    </Auth>
  </Auths>

  <Template>
    <Param Name="CustomColumnsRegexParam" LabelXX="Custom columns for output"     
				OptionsEndPoint="get_custom_fields" OptionsEndPointLabelColumn="ScopeProjectId,Name" 
				OptionsEndPointValueColumn="Key" OptionsExtra="All Custom Columns=(.*);No Custom Columns=$^" 
				OptionsEndPointParameters="CustomColumnsRegex=(.*)"
				OptionsEndPointSortBy="ScopeProjectId desc,Name" MultiSelect="True" MultiSelectSeparator="|"	
               Value="" 
			   Desc="Enter regular expression for custom columns which you like to output. Use Pipe to type keys (internal names for columns). You can use Regex too (e.g. field_100\d+  )"
               
        />	  
    <EndPoint Name="WorklogTemplate"
              ResponseFormat="Json"
              JsonRowFormat="Multicontent"
              ContentType="application/json"
              Body="{$rows$}">
      <Params>
        <Param Type="Placeholder" Name="IssueIdOrKey" Desc="Enter Issue ID or Key" Example="100002 or MYISSUE-1"/>
      </Params>
      <InputColumns>
        <Column Name="visibility.type" Label="VisibilityType" Desc="Enter 'group' or 'role'" Example="group" />
        <Column Name="visibility.value" Label="VisibilityValue" Desc="The name of the group or role to which visibility of this item is restricted." Example="jira-developers" />
        <Column Name="comment" Label="Comment" Raw="True"
                                               ValueTemplate="{ &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
                                               DataType="DT_NTEXT"
                                               />
        <Column Name="comment" Label="CommentFormatted" DataType="DT_NTEXT" Raw="True"/>
        <Column Name="started" Label="StartedAt" DataType="DT_WSTR" Length="100" Desc="Datetime with timezone" Example="2020-02-23T16:20:30.123+0300"/>
        <Column Name="timeSpent" Label="TimeSpent" DataType="DT_WSTR" Length="50" Desc="Defines a time spent in hours and minutes" Example="3h 20m" />
        <Column Name="timeSpentSeconds" Label="TimeSpentInSeconds" DataType="DT_I8" Desc="Defines a time spent in seconds" Example="12000" />
      </InputColumns>
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="50" />
        <Column Name="issueId" Label="IssueId" DataType="DT_WSTR" Length="50" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="author.self" Label="AuthorSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="author.accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="100" />
        <Column Name="author.emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="author.displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="author.active" Label="AuthorIsActive" DataType="DT_BOOL" />
        <Column Name="author.timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="50" />
        <Column Name="author.accountType" Label="AuthorAccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="comment.content" Label="CommentFormatted" DataType="DT_NTEXT" />
        <Column Name="comment.content" Label="Comment" DataType="DT_NTEXT" Functions="[$1]|~|$..content[*].text|~| ,FUN_JSON_TO_TEXT" Desc="Join formatted text blocks using space separator (new lines will be lost)"/>
        <Column Name="updateAuthor.self" Label="UpdateAuthorSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="updateAuthor.accountId" Label="UpdateAuthorAccountId" DataType="DT_WSTR" Length="150" />
        <Column Name="updateAuthor.emailAddress" Label="UpdateAuthorEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="updateAuthor.displayName" Label="UpdateAuthorDisplayName" DataType="DT_WSTR" Length="50" />
        <Column Name="updateAuthor.active" Label="UpdateAuthorActive" DataType="DT_BOOL" />
        <Column Name="updateAuthor.timeZone" Label="UpdateAuthorTimeZone" DataType="DT_WSTR" Length="50" />
        <Column Name="updateAuthor.accountType" Label="UpdateAuthorAccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="created" Label="Created" DataType="DT_DBTIMESTAMP" />
        <Column Name="updated" Label="Updated" DataType="DT_DBTIMESTAMP" />
        <Column Name="started" Label="Started" DataType="DT_DBTIMESTAMP" />
        <Column Name="timeSpent" Label="TimeSpent" DataType="DT_WSTR" Length="50" />
        <Column Name="timeSpentSeconds" Label="TimeSpentInSeconds" DataType="DT_I8" />
        <Column Name="author.avatarUrls.48x48" Label="AuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.24x24" Label="AuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.16x16" Label="AuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.32x32" Label="AuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.48x48" Label="UpdateAuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.24x24" Label="UpdateAuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.16x16" Label="UpdateAuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.32x32" Label="UpdateAuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
    </EndPoint>

    <EndPoint Name="IssuesTemplate" Url="/search?startAt=0&amp;maxResults=100" Method="GET" BatchSize="500" RequestFormat="Csv" Filter="$.issues[*]">
      <Params>
        <Param Name="SearchBy"
               Label="Search by"
               Options="Project;JQL;Key"
              />
        <Param Name="Project"
               Key="jql"
               Required="False"
               OptionsEndPoint="get_projects"
               OptionsEndPointValueColumn="key"
               OptionsEndPointLabelColumn="name"
               ValueTemplate="project=&quot;{$value$}&quot;"
               Type="Query"
               VisibleIf="SearchBy==Project"
               Desc="Specify a project to search issues for"
              />
        <Param Name="JQL"
               Key="jql"
               Required="False"
               Options="Search Ids (IN)=key IN(10001, 10002, 10003);
               Search Keys (IN)=key IN(CS-1, CS-2, CS-3);
               Search Projects (IN)=project IN(PROJ1, PROJ2, PROJ3);
               Search Status (EQUAL)=status='Done';
               Search Date (Expression 1)=created &gt;=-5d;
               Search Date (Expression 2)=created &gt;=startOfMonth() AND created &lt;=now();
               Search Date (Expression 3)=created &gt;=startOfYear() AND created &lt;=startOfDay();
               Search Date (Static)=created >= 2008/12/31;
               Search Date (Static with time)=created >= 2008/12/31 23:59;
               Search Project and Status (AND + IN)=project=CS AND status NOT IN ('Done', 'Open', 'Closed');
               Search Assignee and Created Date=assignee is NOT EMPTY and created &lt; -1d;
               Search Text (Contains - Fuzzy)=Summary ~ 'some words' OR description ~ 'some words';
               Search Text (Contains - Fuzzy Wildcard)=Summary ~ 'some*' OR description ~ 'some*';
               Search Text (Contains - Exact)=Summary ~ '\&quot;exact words\&quot;' OR description ~ '\&quot;exact words\&quot;';
               Search Text (Does Not Contain - Fuzzy)=Summary !~ 'some words' OR description !~ 'some words';
               Search Empty OR Null=fixVersion is empty OR fixVersion is null;
               Search Is Not Empty OR Is Not Null=fixVersion is not empty OR fixVersion is not null;
               Search WAS Operator (previous value)=status WAS &quot;Resolved&quot; BY (jsmith,srogen) BEFORE &quot;2019/02/02&quot;;
               Search WAS IN Operator=status WAS IN (&quot;Resolved&quot;, &quot;In Progress&quot;);
               Search WAS NOT IN Operator=status WAS NOT IN (&quot;Resolved&quot;, &quot;In Progress&quot;);
               Search WAS + BY + DURING (date range)=status WAS &quot;Resolved&quot; BY (jsmith,srogen) DURING(&quot;2019/02/02&quot;, &quot;2020/02/02&quot;);
               Search CHANGED operator=assignee CHANGED;
               Search CHANGED operator (multiple)=status CHANGED FROM &quot;In Progress&quot; TO &quot;Open&quot;"
               Type="Query"
               VisibleIf="SearchBy==JQL"
               Desc="Use JQL to use an advanced mode of searching. Few links are https://www.atlassian.com/blog/jira/jql-the-most-flexible-way-to-search-jira-14 and als check https://wac-cdn.atlassian.com/dam/jcr:241d9c9b-475f-411f-90a2-97ca344442b3/atlassian-jql-cheat-sheet-2.pdf?cdnVersion=2169"
               Example="project=MyProjectKey"
               HelpLink="https://www.atlassian.com/software/jira/guides/expand-jira/jql#advanced-search"
              />
        <Param Name="Key"
              Label="Issue Key(s) or Ids - Comma Separated (PRJA-10,PRJA-13)"
              IsKey="True"
              ReadAs="Id"
              Key="jql"
              Required="False"
              Type="Query"
              VisibleIf="SearchBy==Key"
              Functions="{$rows$}"
              ValueTemplate="Key in ({$value$})"
              Desc="Use comma separated IDs or Keys for Issues. 1000 ids max or JIRA internal limit for Payload."
              />
	    
		
        <Param Name="CustomColumnsRegex" Template="CustomColumnsRegexParam" />				  
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="100" Desc="This must be same as maxResults in URL"/>
		    <Param Name="PagingMaxRowsExpr" Type="Property" Value="$.total" />
		    <Param Name="PagingMaxRowsDataPathExpr" Type="Property" Value="$.issues[*]" />
		
      </Params>
	  <LayoutMap>
          <![CDATA[<?xml version="1.0" encoding="utf-8"?>
            <settings>
              <dataset id="root" readfrominput="True" />
              <map name="Key" src="Key" />
            </settings>]]>
      </LayoutMap>
    </EndPoint>
		
	
    <EndPoint Name="FieldsTemplate" CachedTtl="30" UseRawCache="True" Url="/field" Method="GET" >
	  <Params>
        <Param Name="EnableRawOutputModeSingleRow" Type="Property" Value="True" Hidden="True" />
        <Param Name="RawOutputDataRowTemplate" Type="Property" Value="{data: [$1]}" Hidden="True" />
      </Params>

      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="120" />
        <Column Name="key" Label="Key" DataType="DT_WSTR" Length="120" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="250" />
        <Column Name="custom" Label="Custom" DataType="DT_BOOL" />
        <Column Name="orderable" Label="Orderable" DataType="DT_BOOL" />
        <Column Name="navigable" Label="Navigable" DataType="DT_BOOL" />
        <Column Name="searchable" Label="Searchable" DataType="DT_BOOL" />
        <Column Name="clauseNames" Label="ClauseNames" DataType="DT_WSTR" Length="900" />
        <Column Name="schema.type" Label="SchemaType" DataType="DT_WSTR" Length="200" />
        <Column Name="schema.system" Label="SchemaSystem" DataType="DT_WSTR" Length="200" />
        <Column Name="untranslatedName" Label="UntranslatedName" DataType="DT_WSTR" Length="200" />
        <Column Name="schema.items" Label="SchemaItems" DataType="DT_WSTR" Length="200" />
        <Column Name="schema.custom" Label="SchemaCustom" DataType="DT_WSTR" Length="100" />
        <Column Name="schema.customId" Label="SchemaCustomId" DataType="DT_I8" />
        <Column Name="scope.type" Label="ScopeType" DataType="DT_WSTR" Length="50" />
        <Column Name="scope.project.id" Label="ScopeProjectId" DataType="DT_WSTR" Length="50" />
      </OutputColumns>      
    </EndPoint>
	
  </Template>

  <EndPoints>
  
  

    <!-- ==================
             ORGS
    =================== -->
    <EndPoint Name="get_resources" Label="Read Resources" Url="https://api.atlassian.com/oauth/token/accessible-resources" >
		<OutputColumns>
			<Column Name="id" Label="Id"/>
			<Column Name="name" Label="Name"/>
			<Column Name="url" Label="Url"/>
			<Column Name="scopes" Label="Scopes" DataType="DT_WSTR" Length="1000" />
		</OutputColumns>
    </EndPoint>  
  
    <!-- ==================
             FIELDS
    =================== -->
    <EndPoint Name="get_fields" Label="Read Fields" Template="FieldsTemplate" Filter="$.data[*]">
	  <Params>
        <Param Name="Filter" Type="Property" Value="$.data[*]" 
              Options="All fields=$.data[*];
Custom fields=$.data[?(@custom==true)];
System fields (non-custom)=$.data[?(@custom==false)]
Custom Column name contains=$.data[?(@custom==true  &amp;&amp; @name=~/ProjectACol1|ProjectACol2/)];
Custom Column key contains=$.data[?(@custom==true  &amp;&amp; @key=~/customfield_10001|customfield_10002/)];
Custom Column name starts with=$.data[?(@custom==true  &amp;&amp; @name=~/^order|^survey/)];
Custom Column name ends with=$.data[?(@custom==true  &amp;&amp; @name=~/order$|survey$/)];
Custom Column name exact match=$.data[?(@custom==true  &amp;&amp; @name=~/^ordernumber$|^surveyquestion$/)];
Custom Column without option and textarea type=$.data[?(@.custom==true &amp;&amp; @schema.type!='option' &amp;&amp;  @schema.custom=~/^((?!textarea).)*$/)]" 													
        />
		
			   
      </Params>      
    </EndPoint>
	  <!-- ==================
             Custom FIELDS
    =================== -->
    <EndPoint Name="get_custom_fields" Label="Read Custom Fields" Template="FieldsTemplate" 
	          Filter="$.data[?(@custom==true  &amp;&amp; @key=~/[$CustomColumnsRegex$]/)]">
	  <Params>
		<Param Name="CustomColumnsRegex" Template="CustomColumnsRegexParam"/>	  
      </Params> 
    </EndPoint>

    <!-- =======================
             ISSUE TYPES
    ======================== -->
    <EndPoint Name="get_types" Label="Read Issue Types" Url="/issuetype" Method="GET" Cached="True" CachedTtl="60">
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="50" />
        <Column Name="description" Label="Description" DataType="DT_WSTR" Length="1000" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="200" />
        <Column Name="untranslatedName" Label="UntranslatedName" DataType="DT_WSTR" Length="200" />
        <Column Name="subtask" Label="Subtask" DataType="DT_BOOL" />
        <Column Name="avatarId" Label="AvatarId" DataType="DT_I8" />
        <Column Name="hierarchyLevel" Label="HierarchyLevel" DataType="DT_I8" />
        <Column Name="scope.type" Label="ScopeType" DataType="DT_WSTR" Length="50" />
        <Column Name="scope.project.id" Label="ScopeProjectId" DataType="DT_WSTR" Length="50" />
        <Column Name="iconUrl" Label="IconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
      </OutputColumns>
    </EndPoint>

    <!-- =====================
               USERS 
    ====================== -->
    <EndPoint Name="get_users" Label="Read Users" Url="/users/search?startAt=0&amp;maxResults=50" Method="GET">
      <Params>
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />
      </Params>
      <OutputColumns>
        <Column Name="displayName" Label="DisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="emailAddress" Label="EmailAddress" DataType="DT_WSTR" Length="200" />
        <Column Name="accountId" Label="AccountId" DataType="DT_WSTR" Length="150" />
        <Column Name="accountType" Label="AccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="active" Label="Active" DataType="DT_BOOL" />
        <Column Name="locale" Label="Locale" DataType="DT_WSTR" Length="50" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
    </EndPoint>

    <!-- INSERT USER -->
    <EndPoint Name="create_user" Label="Create User" Url="/user" Method="POST"
              JsonRowFormat="Multicontent"
               ContentType="application/json"
               Body="{$rows$}">
      <InputColumns>
        <Column Name="password" Label="Password" DataType="DT_WSTR" Length="50" Desc="If password is not supplied, random one is generated" />
        <Column Name="emailAddress" Label="EmailAddress" DataType="DT_WSTR" Length="200" />
        <Column Name="displayName" Label="DisplayName" DataType="DT_WSTR" Length="200" />
      </InputColumns>
      <OutputColumns>
        <Column Name="displayName" Label="DisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="emailAddress" Label="EmailAddress" DataType="DT_WSTR" Length="200" />
        <Column Name="accountId" Label="AccountId" DataType="DT_WSTR" Length="150" />
        <Column Name="accountType" Label="AccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="active" Label="Active" DataType="DT_BOOL" />
        <Column Name="locale" Label="Locale" DataType="DT_WSTR" Length="50" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
    </EndPoint>

    <!-- DELETE USER -->
    <EndPoint Name="delete_user" Label="Delete User" Url="/user" Method="DELETE">
      <Params>
        <Param Name="AccountId" Key="accountId" Type="Query" Example="5b10ac8d82e05b22cc7d4ef5"/>
		<Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
      <OutputColumns>
        <Column Name="Response" DataType="DT_NTEXT" />
      </OutputColumns>
      <InputColumns>
        <Column Name="AccountId" DataType="DT_WSTR" MapToParam="True" Key="True" />
      </InputColumns>	  	  
    </EndPoint>

    <!-- ====================
             PROJECTS 
    ===================== -->
    <EndPoint Name="get_projects" Label="Read Projects" Url="/project/search" Method="GET" Filter="$.values[*]">
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_I8" />
        <Column Name="key" Label="Key" DataType="DT_WSTR" Length="50" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="100" />
        <Column Name="projectCategory.id" Label="ProjectCategoryId" DataType="DT_WSTR" Length="50" />
        <Column Name="projectCategory.name" Label="ProjectCategoryName" DataType="DT_WSTR" Length="50" />
        <Column Name="projectCategory.description" Label="ProjectCategoryDescription" DataType="DT_WSTR" Length="150" />
        <Column Name="projectCategory.self" Label="ProjectCategorySelf" DataType="DT_WSTR" Length="150" />
        <Column Name="simplified" Label="Simplified" DataType="DT_BOOL" />
        <Column Name="style" Label="Style" DataType="DT_WSTR" Length="50" />
        <Column Name="insight.totalIssueCount" Label="InsightTotalIssueCount" DataType="DT_I8"/>
        <Column Name="insight.lastIssueUpdateTime" Label="InsightLastIssueUpdateTime" DataType="DT_DBTIMESTAMP"/>
        <Column Name="avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
    </EndPoint>

    <!-- CREATE PROJECT -->
    <EndPoint Name="create_project" Label="Create Project" Url="/project" Method="POST"
              ContentType="application/json"
              Body="{$rows$}"
              JsonRowFormat="Multicontent">
      <InputColumns>
        <Column Name="key" Label="ProjectKey" DataType="DT_WSTR" Length="50" Desc="A key uniquely representing your project" Example="PRJ" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="500" />
        <Column Name="projectTypeKey" Label="ProjectTypeKey" Desc="The project type, which dictates the application-specific feature set. Possible values: business, service_desk, software" Example="business" DataType="DT_WSTR" Length="100" />
        <Column Name="description" Label="Description" DataType="DT_WSTR" Length="2000" />
        <Column Name="leadAccountId" Label="LeadAccountId" DataType="DT_WSTR" Length="100" Desc="The account ID of the project lead" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2" />
        <Column Name="url" Label="Url" DataType="DT_WSTR" Length="400" Desc="A link to information about this project, such as project documentation" />
        <Column Name="assigneeType" Label="AssigneeType" Desc="The default assignee when creating issues for this project. Possible values: PROJECT_LEAD, UNASSIGNED" Example="PROJECT_LEAD" DataType="DT_WSTR" Length="100" />
        <Column Name="avatarId" Label="AvatarId" DataType="DT_I8" Desc="An integer value for the project's avatar."/>
        <Column Name="issueSecurityScheme" Label="IssueSecurityScheme" DataType="DT_I8" Desc="The ID of the issue security scheme for the project, which enables you to control who can and cannot view issues." />
        <Column Name="permissionScheme" Label="PermissionScheme" DataType="DT_I8" Desc="The ID of the permission scheme for the project."/>
        <Column Name="notificationScheme" Label="NotificationScheme" DataType="DT_I8" Desc="The ID of the notification scheme for the project."/>
        <Column Name="categoryId" Label="CategoryId" DataType="DT_I8" Desc="The ID of the project's category." />
      </InputColumns>
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_I8" />
        <Column Name="key" Label="Key" DataType="DT_WSTR" Length="50" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="200" />
      </OutputColumns>
    </EndPoint>

    <!-- UPSERT PROJECT -->
    <EndPoint Name="upsert_project" Label="Upsert Project" Url="/project/[$ProjectIdOrKey$]" Method="PUT"
              ContentType="application/json"
              Body="{$rows$}"
              JsonRowFormat="Multicontent">
      <Params>
        <Param Name="ProjectIdOrKey" Type="Placeholder" />
      </Params>
      <InputColumns>
        <Column Name="key" Label="ProjectKey" DataType="DT_WSTR" Length="50" Desc="A key uniquely representing your project" Example="PRJ" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="100" />
        <Column Name="description" Label="Description" DataType="DT_WSTR" Length="300" />
        <Column Name="leadAccountId" Label="LeadAccountId" DataType="DT_WSTR" Length="100" Desc="The account ID of the project lead" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2" />
        <Column Name="url" Label="Url" DataType="DT_WSTR" Length="400" Desc="A link to information about this project, such as project documentation" />
        <Column Name="assigneeType" Label="AssigneeType" Desc="The default assignee when creating issues for this project. Possible values: PROJECT_LEAD, UNASSIGNED" Example="PROJECT_LEAD" DataType="DT_WSTR" Length="100" />
        <Column Name="avatarId" Label="AvatarId" DataType="DT_I8" Desc="An integer value for the project's avatar."/>
        <Column Name="issueSecurityScheme" Label="IssueSecurityScheme" DataType="DT_I8" Desc="The ID of the issue security scheme for the project, which enables you to control who can and cannot view issues." />
        <Column Name="permissionScheme" Label="PermissionScheme" DataType="DT_I8" Desc="The ID of the permission scheme for the project."/>
        <Column Name="notificationScheme" Label="NotificationScheme" DataType="DT_I8" Desc="The ID of the notification scheme for the project."/>
        <Column Name="categoryId" Label="CategoryId" DataType="DT_I8" Desc="The ID of the project's category." />
      </InputColumns>
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="50" />
        <Column Name="key" Label="Key" DataType="DT_WSTR" Length="50" />
        <Column Name="name" Label="Name" DataType="DT_WSTR" Length="100" />
        <Column Name="description" Label="Description" DataType="DT_NTEXT" />
        <Column Name="issueTypes" Label="IssueTypes" DataType="DT_NTEXT" />
        <Column Name="expand" Label="Expand" DataType="DT_WSTR" Length="300" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="entityId" Label="EntityId" DataType="DT_WSTR" Length="100" />
        <Column Name="uuid" Label="Uuid" DataType="DT_WSTR" Length="100" />
        <Column Name="properties" Label="Properties" DataType="DT_NTEXT" />
        <Column Name="components" Label="Components" DataType="DT_NTEXT" />
        <Column Name="lead.self" Label="LeadSelf" DataType="DT_WSTR" Length="500" />
        <Column Name="lead.accountId" Label="LeadAccountId" DataType="DT_WSTR" Length="100" />
        <Column Name="lead.avatarUrls.48x48" Label="LeadAvatarUrls48x48" DataType="DT_WSTR" Length="700" />
        <Column Name="lead.avatarUrls.24x24" Label="LeadAvatarUrls24x24" DataType="DT_WSTR" Length="700" />
        <Column Name="lead.avatarUrls.16x16" Label="LeadAvatarUrls16x16" DataType="DT_WSTR" Length="700" />
        <Column Name="lead.avatarUrls.32x32" Label="LeadAvatarUrls32x32" DataType="DT_WSTR" Length="700" />
        <Column Name="lead.displayName" Label="LeadDisplayName" DataType="DT_WSTR" Length="100" />
        <Column Name="lead.active" Label="LeadActive" DataType="DT_BOOL" />
        <Column Name="projectTypeKey" Label="ProjectTypeKey" DataType="DT_WSTR" Length="50" />
        <Column Name="assigneeType" Label="AssigneeType" DataType="DT_WSTR" Length="50" />
        <Column Name="versions" Label="Versions" DataType="DT_WSTR" Length="50" />
        <Column Name="simplified" Label="Simplified" DataType="DT_BOOL" />
        <Column Name="style" Label="Style" DataType="DT_WSTR" Length="50" />
        <Column Name="isPrivate" Label="IsPrivate" DataType="DT_BOOL" />
        <Column Name="roles.atlassian-addons-project-access" Label="RolesAtlassianAddonsProjectAccess" DataType="DT_WSTR" Length="500" />
        <Column Name="roles.Administrator" Label="RolesAdministrator" DataType="DT_WSTR" Length="500" />
        <Column Name="roles.Viewer" Label="RolesViewer" DataType="DT_WSTR" Length="500" />
        <Column Name="roles.Member" Label="RolesMember" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
    </EndPoint>

    <!-- DELETE PROJECT -->
    <EndPoint Name="delete_project" Label="Delete Project" Url="/project/[$ProjectIdOrKey$]" Method="DELETE"
              ResponseFormat="Json" >
      <Params>
        <Param Name="ProjectIdOrKey" IsKey="True" ReadAs="Id" Type="Placeholder" Desc="Project ID or Key, uniquely representing a project" Example="10002, MYPRJ" />
        <Param Name="EnableUndo" Key="enableUndo" Type="Query" />
		<Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
      <OutputColumns>
        <Column Name="Response" DataType="DT_NTEXT" />
      </OutputColumns>
      <InputColumns>
        <Column Name="ProjectIdOrKey" Label="Id" DataType="DT_WSTR" MapToParam="True" Key="True" />
      </InputColumns>
    </EndPoint>

    <!-- =====================
            READ ISSUES
    ====================== -->
    <EndPoint Name="get_issues" Template="IssuesTemplate" Label="Read Issues" >
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_I8" />
        <Column Name="key" Label="Key" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.project.key" Label="ProjectKey" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.project.name" Label="ProjectName" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.status.name" Label="StatusName" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.summary" Label="Summary" DataType="DT_WSTR" Length="2000" />
        <Column Name="fields.created" Label="Created" DataType="DT_DBTIMESTAMP" />
        <Column Name="fields.updated" Label="Updated" DataType="DT_DBTIMESTAMP" />
        <Column Name="fields.description.content" Label="Description" DataType="DT_NTEXT" Functions="[$1]|~|$..content[*].text|~| ,FUN_JSON_TO_TEXT" Desc="Join formatted text blocks using space separator (new lines will be lost)"/>
        <Column Name="fields.description.content" Label="DescriptionFormatted" DataType="DT_NTEXT" />
	
        <Column Name="fields.creator.accountId" Label="CreatorAccountId" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.creator.emailAddress" Label="CreatorEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.reporter.accountId" Label="ReporterAccountId" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.reporter.emailAddress" Label="ReporterEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.assignee.accountId" Label="AssigneeAccountId" DataType="DT_WSTR" Length="100"/>
        <Column Name="fields.assignee.emailAddress" Label="AssigneeEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.resolution.id" Label="ResolutionId" DataType="DT_I8" />
        <Column Name="fields.resolution.description" Label="ResolutionDescription" DataType="DT_WSTR" Length="4000" />
        <Column Name="fields.resolution.name" Label="ResolutionName" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.resolution" Label="Resolution" DataType="DT_NTEXT" />
        <Column Name="fields.timespent" Label="TimespentInSeconds" DataType="DT_I8" />
        <Column Name="fields.duedate" Label="DueDate" DataType="DT_DBDATE" />
        <Column Name="expand" Label="Expand" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.statuscategorychangedate" Label="StatusCategoryChangeDate" DataType="DT_DBTIMESTAMP" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.issuetype.self" Label="IssueTypeSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.issuetype.id" Label="IssueTypeId" DataType="DT_I8" />
        <Column Name="fields.issuetype.description" Label="IssueTypeDescription" DataType="DT_NTEXT" />
        <Column Name="fields.issuetype.iconUrl" Label="IssueTypeIconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.issuetype.name" Label="IssueTypeName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.issuetype.subtask" Label="IssueTypeSubtask" DataType="DT_BOOL" />
        <Column Name="fields.issuetype.avatarId" Label="IssueTypeAvatarId" DataType="DT_I4" />
        <Column Name="fields.issuetype.entityId" Label="IssueTypeEntityId" DataType="DT_GUID" />
        <Column Name="fields.issuetype.hierarchyLevel" Label="IssueTypeHierarchyLevel" DataType="DT_I4" />

        <Column Name="fields.project.self" Label="ProjectSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.project.id" Label="ProjectId" DataType="DT_I8" />
        
        
        <Column Name="fields.project.projectTypeKey" Label="ProjectTypeKey" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.project.simplified" Label="ProjectSimplified" DataType="DT_BOOL" />
        <Column Name="fields.project.avatarUrls.48x48" Label="ProjectAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.project.avatarUrls.24x24" Label="ProjectAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.project.avatarUrls.16x16" Label="ProjectAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.project.avatarUrls.32x32" Label="ProjectAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.fixVersions" Label="FixVersions" DataType="DT_NTEXT" />
        <Column Name="fields.aggregatetimespent" Label="AggregateTimespentInSeconds" DataType="DT_I8" />

        <Column Name="fields.resolutiondate" Label="ResolutionDate" DataType="DT_DBTIMESTAMP" />
        <Column Name="fields.workratio" Label="WorkRatio" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.watches.self" Label="WatchesSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.watches.watchCount" Label="WatchesWatchCount" DataType="DT_I4" />
        <Column Name="fields.watches.isWatching" Label="WatchesIsWatching" DataType="DT_BOOL"/>
        <Column Name="fields.lastViewed" Label="LastViewed" DataType="DT_DBTIMESTAMP" />
        
        <Column Name="fields.priority.self" Label="PrioritySelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.priority.iconUrl" Label="PriorityIconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.priority.name" Label="PriorityName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.priority.id" Label="PriorityId" DataType="DT_I4" />
        <Column Name="fields.labels" Label="Labels" DataType="DT_NTEXT" />
        <Column Name="fields.aggregatetimeoriginalestimate" Label="AggregateTimeOriginalEstimate" DataType="DT_WSTR" Length="50"/>
        <Column Name="fields.timeestimate" Label="TimeEstimate" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.versions" Label="Versions" DataType="DT_NTEXT" />
        <Column Name="fields.issuelinks" Label="IssueLinks" DataType="DT_NTEXT" />
        <Column Name="fields.assignee.self" Label="AssigneeSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.assignee.avatarUrls.48x48" Label="AssigneeAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.assignee.avatarUrls.24x24" Label="AssigneeAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.assignee.avatarUrls.16x16" Label="AssigneeAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.assignee.avatarUrls.32x32" Label="AssigneeAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.assignee.displayName" Label="AssigneeDisplayName" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.assignee.active" Label="AssigneeActive" DataType="DT_BOOL" Length="32" />
        <Column Name="fields.assignee.timeZone" Label="AssigneeTimeZone" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.assignee.accountType" Label="AssigneeAccountType" DataType="DT_WSTR" Length="100" />
        
        <Column Name="fields.status.self" Label="StatusSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.status.description" Label="StatusDescription" DataType="DT_NTEXT" />
        <Column Name="fields.status.iconUrl" Label="StatusIconUrl" DataType="DT_WSTR" Length="500" />
        
        <Column Name="fields.status.id" Label="StatusId" DataType="DT_I4" />
        <Column Name="fields.status.statusCategory.self" Label="StatusCategorySelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.status.statusCategory.id" Label="StatusCategoryId" DataType="DT_I4" />
        <Column Name="fields.status.statusCategory.key" Label="StatusCategoryKey" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.status.statusCategory.colorName" Label="StatusCategoryColorName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.status.statusCategory.name" Label="StatusCategoryName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.components" Label="Components" DataType="DT_NTEXT" />
        <Column Name="fields.timeoriginalestimate" Label="TimeOriginalEstimate" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.description.version" Label="DescriptionVersion" DataType="DT_I4" />
        <Column Name="fields.description.type" Label="DescriptionType" DataType="DT_WSTR" Length="50" />

        <Column Name="fields.security" Label="Security" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.aggregatetimeestimate" Label="AggregateTimeEstimate" DataType="DT_I8" />

        <Column Name="fields.creator.self" Label="CreatorSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.creator.avatarUrls.48x48" Label="CreatorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.creator.avatarUrls.24x24" Label="CreatorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.creator.avatarUrls.16x16" Label="CreatorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.creator.avatarUrls.32x32" Label="CreatorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.creator.displayName" Label="CreatorDisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="fields.creator.active" Label="CreatorActive" DataType="DT_BOOL" />
        <Column Name="fields.creator.timeZone" Label="CreatorTimeZone" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.creator.accountType" Label="CreatorAccountType" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.subtasks" Label="Subtasks" DataType="DT_NTEXT" />
        <Column Name="fields.reporter.self" Label="ReporterSelf" DataType="DT_WSTR" Length="150" />

        <Column Name="fields.reporter.avatarUrls.48x48" Label="ReporterAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.reporter.avatarUrls.24x24" Label="ReporterAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.reporter.avatarUrls.16x16" Label="ReporterAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.reporter.avatarUrls.32x32" Label="ReporterAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.reporter.displayName" Label="ReporterDisplayName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.reporter.active" Label="ReporterActive" DataType="DT_BOOL"  />
        <Column Name="fields.reporter.timeZone" Label="ReporterTimeZone" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.reporter.accountType" Label="ReporterAccountType" DataType="DT_WSTR" Length="100" />
		<Column Name="fields.aggregateprogress.percent" Label="AggregateProgressPercent" DataType="DT_I4" />
        <Column Name="fields.aggregateprogress.progress" Label="AggregateProgressInSeconds" DataType="DT_I8" />
        <Column Name="fields.aggregateprogress.total" Label="AggregateProgressTotalInSeconds" DataType="DT_I8" />
        <Column Name="fields.environment.content" Label="Environment" DataType="DT_NTEXT" Functions="[$1]|~|$..content[*].text|~| ,FUN_JSON_TO_TEXT" Desc="Join formatted text blocks using space separator (new lines will be lost)"/>
        <Column Name="fields.environment.content" Label="EnvironmentFormatted" DataType="DT_NTEXT" />	
        
        <Column Name="fields.progress.progress" Label="ProgressInSeconds" DataType="DT_I8" />
        <Column Name="fields.progress.total" Label="ProgressTotalInSeconds" DataType="DT_I8" />
        <Column Name="fields.votes.self" Label="VotesSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.votes.votes" Label="Votes" DataType="DT_I4" />
        <Column Name="fields.votes.hasVoted" Label="HasVoted" DataType="DT_BOOL"/>
        <Column Name="fields.parent.id" Label="ParentId" DataType="DT_I4" />
        <Column Name="fields.parent.key" Label="ParentKey" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.self" Label="ParentSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.parent.fields.summary" Label="ParentSummary" DataType="DT_WSTR" Length="2000" />
        <Column Name="fields.parent.fields.status.self" Label="ParentStatusSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.parent.fields.status.description" Label="ParentStatusDescription" DataType="DT_WSTR" Length="2000" />
        <Column Name="fields.parent.fields.status.iconUrl" Label="ParentStatusIconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.parent.fields.status.name" Label="ParentStatusName" DataType="DT_WSTR" Length="100" />
        <Column Name="fields.parent.fields.status.id" Label="ParentStatusId" DataType="DT_I8" />
        <Column Name="fields.parent.fields.status.statusCategory.self" Label="ParentStatusCategorySelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.parent.fields.status.statusCategory.id" Label="ParentStatusCategoryId" DataType="DT_I4" />
        <Column Name="fields.parent.fields.status.statusCategory.key" Label="ParentStatusCategoryKey" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.fields.status.statusCategory.colorName" Label="ParentStatusCategoryColorName" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.fields.status.statusCategory.name" Label="ParentStatusCategoryName" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.fields.priority.self" Label="ParentprioritySelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.parent.fields.priority.iconUrl" Label="ParentpriorityIconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.parent.fields.priority.name" Label="ParentpriorityName" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.fields.priority.id" Label="ParentpriorityId" DataType="DT_I4" />
        <Column Name="fields.parent.fields.issuetype.self" Label="ParentIssueTypeSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.parent.fields.issuetype.id" Label="ParentIssueTypeId" DataType="DT_I8" />
        <Column Name="fields.parent.fields.issuetype.description" Label="ParentIssueTypeDescription" DataType="DT_WSTR" Length="2000" />
        <Column Name="fields.parent.fields.issuetype.iconUrl" Label="ParentIssueTypeIconUrl" DataType="DT_WSTR" Length="500" />
        <Column Name="fields.parent.fields.issuetype.name" Label="ParentIssueTypeName" DataType="DT_WSTR" Length="50" />
        <Column Name="fields.parent.fields.issuetype.subtask" Label="ParentIssueTypeSubtask" DataType="DT_BOOL" />
        <Column Name="fields.parent.fields.issuetype.avatarId" Label="ParentIssueTypeAvatarId" DataType="DT_I4" />
        <Column Name="fields.parent.fields.issuetype.entityId" Label="ParentIssueTypeEntityId" DataType="DT_GUID" />
        <Column Name="fields.parent.fields.issuetype.hierarchyLevel" Label="ParentIssueTypeHierarchyLevel" DataType="DT_I4" />
        <Column Name="fields.assignee" Label="Assignee" DataType="DT_WSTR" Length="150" />
        <Column Name="fields.resolution.self" Label="ResolutionSelf" DataType="DT_WSTR" Length="150" />

        <!-- DYNAMIC CUSTOM FIELDS  -->

        <!-- Textbox, Number, Date, Url... customfield_123: "xx" or customfield_123: ["tag1", "tag2"] -->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]" Desc="[$parent.name$]" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true)]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=array;DT_BOOL=?;"
        />

        <!-- Dropdown Single / Radio (value - i.e. label)... customfield_123: {value: xx} -->
        <Column Name="fields.[$parent.key$].value" Label="[$parent.key$]_value" Desc="[$parent.name$]_value" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=array;DT_BOOL=?;"
        />
		<!-- Dropdown Single / Radio (id)... customfield_123: {id: xx} -->
        <Column Name="fields.[$parent.key$].id" Label="[$parent.key$]_id" Desc="[$parent.name$]_id" DataType="DT_WSTR" Length="20"
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=array;DT_BOOL=?;"
        />		

        <!-- Multi Select Checkbox / List ... customfield_123: [{value: xx}, {value: yy}, {value: zz}]. $.data[*].value is used becuase when Array format needs filter we wrap behind the scene unde { data: <content> } so filter can be invoked at root level-->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]_values" Desc="[$parent.name$]_values" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='array')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=array;DT_BOOL=?;"
                Functions="[$1]|~|$.data[*].value|~|,,FUN_JSON_TO_TEXT"
        />
        
        <!-- Paragraph ... customfield_123: { content:[ {content: [{text: zzz},{text: zzz}...]} , {content: [{text: zzz}, {text: zzz},..]} , ...] } -->
        <Column Name="fields.[$parent.key$].content" Label="[$parent.key$]_text" Desc="[$parent.name$]_text Join formatted text blocks using space separator (new lines will be lost)" DataType="DT_NTEXT" 
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.custom=~/textarea$/)]"
                ColumnInfoMap="Name=key;"
                Functions="[$1]|~|$..text|~| ,FUN_JSON_TO_TEXT"           
        />

      </OutputColumns>
    </EndPoint>

    <!-- INSERT ISSUES -->
    <EndPoint Name="create_issues" Label="Create Issues" Url="/issue/bulk" Method="POST"
              BatchSize="100" ContentType="application/json" DotAsPath="True" Filter="$.issues[*]">
      <Body>
        <![CDATA[{ "issueUpdates" : {$rows$} } ]]>
      </Body>
      <InputColumns>
        <Column Name="fields.project.id" Label="ProjectId" DataType="DT_WSTR" Length="50" Desc="Project in which to create an issue. Must use this field or ProjectKey"/>
        <Column Name="fields.project.key" Label="ProjectKey" DataType="DT_WSTR" Length="50" Desc="Project in which to create an issue. Must use this field or ProjectId"/>
        <Column Name="fields.summary" Label="Summary"  DataType="DT_WSTR" Length="150" Desc="Issue title"/>
        <Column Name="fields.description" Label="Description" Raw="True"
                                                              ValueTemplate="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
                                                              DataType="DT_NTEXT"
                                                               />
        <Column Name="fields.description" Label="DescriptionFormatted" DataType="DT_NTEXT"  Raw="True"
			Example="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;Your description&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
            HelpLink="https://community.developer.atlassian.com/t/how-to-show-description-text-in-visual-format-instead-of-text-while-creating-issue-using-rest-call/37667"
			/>
        <Column Name="fields.environment" Label="Environment" Raw="True"
                                                              ValueTemplate="{ &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
                                                              DataType="DT_NTEXT"
                                                               />
        <Column Name="fields.environment_formatted" Label="EnvironmentFormatted" Desc="" DataType="DT_NTEXT"
			Raw="True"
            Example="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;Your description&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
            HelpLink="https://community.developer.atlassian.com/t/how-to-show-description-text-in-visual-format-instead-of-text-while-creating-issue-using-rest-call/37667"
			/>
        <Column Name="fields.issuetype.id" Label="IssueTypeId"  DataType="DT_WSTR" Length="50" />
        <Column Name="fields.issuetype.name" Label="IssueTypeName" DataType="DT_WSTR" Length="50"/>
        <Column Name="fields.assignee.id" Label="AssigneeUserId" DataType="DT_WSTR" Length="50" Desc="User ID representing a user assigned to an issue" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2"/>
        <Column Name="fields.reporter.id" Label="ReporterUserId" DataType="DT_WSTR" Length="50" Desc="User ID representing a user who reported an issue" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2"/>  />
        <Column Name="fields.labels" Label="Labels" Raw="True" Desc="Labels, assigned to an issue in JSON string array format" Example="[&quot;myBadge&quot;,&quot;anotherBadge&quot;]" DataType="DT_WSTR" Length="2000" />
        <Column Name="fields.duedate" Label="DueDate" DataType="DT_DBDATE" Desc="A date refering to due date of an issue" Example="2029-11-25" />
		
 		<!-- all custom fields (to treat type as raw add in RawInfoMap and DT_RAW both places for now TFS8293)-->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]" Desc="[$parent.name$]" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.custom=~/^((?!textarea).)*$/)]"
                ColumnInfoMap="Name=key;DataType=schema.type;Raw=schema.type"
				RawInfoMap="option,array,user,team"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=option,array,user,team;DT_BOOL=?;"
				/>
		
		<!-- all custom fields with type=option (dropdown) support easy write by value or id -->
        <Column Name="fields.[$parent.key$].value" Label="[$parent.key$]_value" Desc="Set [$parent.name$] value by option text" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_BOOL=?;"
				
				/>
        <Column Name="fields.[$parent.key$].id" Label="[$parent.key$]_id" Desc="Set [$parent.name$] value by option item id" DataType="DT_WSTR" Length="20"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_BOOL=?;"
				/>				
				
        <!-- Paragraph ... customfield_123: { content:[ {content: [{text: zzz},{text: zzz}...]} , {content: [{text: zzz}, {text: zzz},..]} , ...] } -->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]_text" Desc="[$parent.name$]_text" DataType="DT_NTEXT" 
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.custom=~/textarea$/)]"
                ColumnInfoMap="Name=key"
				Raw="True"
                ValueTemplate="{
          &quot;type&quot;: &quot;doc&quot;,
          &quot;version&quot;: 1,
          &quot;content&quot;: [
            {
              &quot;type&quot;: &quot;paragraph&quot;,
              &quot;content&quot;: [
                {
                  &quot;type&quot;: &quot;text&quot;,
                  &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;
                }
              ]
            }
          ]
        }"         
        />
		
      </InputColumns>
      <OutputColumns>
        <Column Name="id" DataType="DT_WSTR" Length="50" />
        <Column Name="key" DataType="DT_WSTR" Length="50" />
        <Column Name="self" DataType="DT_WSTR" Length="450" />
      </OutputColumns>
    </EndPoint>

    <!-- UPDATE ISSUES -->
    <EndPoint Name="update_issue" Label="Update Issue" 
              Url="/issue/[$IssueIdOrKey$]" Method="PUT"
              ContentType="application/json" DotAsPath="True" JsonRowFormat="Multicontent">
      <Params>
        <Param Name="IssueIdOrKey" Type="Placeholder" 
               Desc="Enter Issue ID or Key" 
               Example="100002 or MYISSUE-1"
               ReadAs="Id"
               IsKey="True"
               />
        <Param Name="NotifyUsers" Key="notifyUsers" Options=";true;false" Type="Query" Value="false" Desc="Whether a notification email about the issue update is sent to all watchers. Possible values: true, false" Example="false" />
        <Param Name="OverrideScreenSecurity" Options=";true;false" Key="overrideScreenSecurity" Type="Query" Value="false" Desc="Whether screen security should be overridden to enable hidden fields to be edited. Possible values: true, false" Example="true" />
        <Param Name="OverrideEditableFlag" Options=";true;false" Key="overrideEditableFlag" Type="Query" Value="false" Desc="Whether screen security should be overridden to enable uneditable fields to be edited. Possible values: true, false" Example="false" />
		<Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
      <Body>
        <![CDATA[ {$rows$} ]]>
      </Body>
      <OutputColumns>
        <Column Name="body" DataType="DT_WSTR" />
      </OutputColumns>
      <InputColumns>
        <Column Name="IssueIdOrKey" Label="Id" MapToParam="True" Key="True" DataType="DT_STR" Length="50" ExcludeFromRowMap="True" Desc="Issue Id or Key" />
        <Column Name="fields.project.id" Label="ProjectId" DataType="DT_WSTR" Length="50" Desc="Project in which to create an issue. Must use this field or ProjectKey"/>
        <Column Name="fields.project.key" Label="ProjectKey" DataType="DT_WSTR" Length="50" Desc="Project in which to create an issue. Must use this field or ProjectId"/>
        <Column Name="fields.summary" Label="Summary"  DataType="DT_WSTR" Length="150" Desc="Issue title"/>
        <Column Name="fields.description" Label="Description" Raw="True"
                                                              ValueTemplate="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
                                                              DataType="DT_NTEXT"
                                                              />
        <Column Name="fields.description" Label="DescriptionFormatted" DataType="DT_NTEXT" 
			Raw="True"
			Example="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;Your description&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
            HelpLink="https://community.developer.atlassian.com/t/how-to-show-description-text-in-visual-format-instead-of-text-while-creating-issue-using-rest-call/37667"
			/>
			
        <Column Name="fields.environment" Label="Environment" Raw="True"
                                                              ValueTemplate="{ &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
                                                              DataType="DT_NTEXT"
                                                               />
        <Column Name="fields.environment_formatted" Label="EnvironmentFormatted" Desc="" DataType="DT_NTEXT"  
			Raw="True" 
			Example="{  &quot;type&quot;: &quot;doc&quot;, &quot;version&quot;: 1, &quot;content&quot;: [ { &quot;type&quot;: &quot;paragraph&quot;, &quot;content&quot;: [ { &quot;text&quot;: &quot;Your description&quot;, &quot;type&quot;: &quot;text&quot; } ] } ] }"
            HelpLink="https://community.developer.atlassian.com/t/how-to-show-description-text-in-visual-format-instead-of-text-while-creating-issue-using-rest-call/37667"
			/>
        <Column Name="fields.issuetype.id" Label="IssueTypeId"  DataType="DT_WSTR" Length="50" />
        <Column Name="fields.issuetype.name" Label="IssueTypeName" DataType="DT_WSTR" Length="50"/>
        <Column Name="fields.assignee.id" Label="AssigneeUserId" DataType="DT_WSTR" Length="50" Desc="User ID representing a user assigned to an issue" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2"/>
        <Column Name="fields.reporter.id" Label="ReporterUserId" DataType="DT_WSTR" Length="50" Desc="User ID representing a user who reported an issue" Example="12551:12be2e5a-9ebf-1235-be58-c3ea8c98b9e2"/>  />
        <Column Name="fields.labels" Label="Labels" Desc="Labels, assigned to an issue in JSON string array format"
                                                    Raw="True"
                                                    Example="[&quot;myBadge&quot;,&quot;anotherBadge&quot;]"
                                                    DataType="DT_WSTR" 
													Length="2000"
													/>

        <Column Name="fields.duedate" Label="DueDate" DataType="DT_DBDATE" Desc="A date refering to due date of an issue" Example="2029-11-25" />

 		<!-- all custom fields (to treat type as raw add in RawInfoMap and DT_RAW both places for now TFS8293)-->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]" Desc="[$parent.name$]" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.custom=~/^((?!textarea).)*$/)]"
                ColumnInfoMap="Name=key;DataType=schema.type;Raw=schema.type"
				RawInfoMap="option,array,user,team"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_RAW=option,array,user,team;DT_BOOL=?;"
				/>
		
        <!-- all custom fields with type=option (dropdown) support easy write by value or id -->
        <Column Name="fields.[$parent.key$].value" Label="[$parent.key$]_value" Desc="Set [$parent.name$] value by option text" DataType="DT_WSTR" Length="2000"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_BOOL=?;"
				
				/>
        
        <Column Name="fields.[$parent.key$].id" Label="[$parent.key$]_id" Desc="Set [$parent.name$] value by option item id" DataType="DT_WSTR" Length="20"
                Expand="True"
                DataEndPoint="get_fields"
                DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.type=='option')]"
                ColumnInfoMap="Name=key;DataType=schema.type"
                DataTypeMap="DT_DBDATE=date;DT_DBTIMESTAMP=datetime;DT_NUMERIC=number;DT_BOOL=?;"
				/>				
				
        <!-- Paragraph ... customfield_123: { content:[ {content: [{text: zzz},{text: zzz}...]} , {content: [{text: zzz}, {text: zzz},..]} , ...] } -->
        <Column Name="fields.[$parent.key$]" Label="[$parent.key$]_text" Desc="[$parent.name$]_text" DataType="DT_NTEXT" 
                Expand="True"
                DataEndPoint="get_custom_fields"
				DataEndPointParameters="Filter=$.data[?(@.custom==true &amp;&amp; @schema.custom=~/textarea$/)]"
                ColumnInfoMap="Name=key"
				Raw="True"
                ValueTemplate="{
          &quot;type&quot;: &quot;doc&quot;,
          &quot;version&quot;: 1,
          &quot;content&quot;: [
            {
              &quot;type&quot;: &quot;paragraph&quot;,
              &quot;content&quot;: [
                {
                  &quot;type&quot;: &quot;text&quot;,
                  &quot;text&quot;: &quot;&lt;&lt;{$value$},FUN_JSONENC&gt;&gt;&quot;
                }
              ]
            }
          ]
        }"         
        />		
		
      </InputColumns>
    </EndPoint>

    <!-- DELETE ISSUE -->
    <EndPoint Name="delete_issue" Label="Delete Issue" Url="/issue/[$IssueIdOrKey$]" Method="DELETE"
              ResponseFormat="Json" >
      <Params>
        <Param Name="IssueIdOrKey" IsKey="True" Type="Placeholder" Desc="Enter Issue ID or Key" Example="100002 or MYISSUE-1"/>
        <Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
      <OutputColumns>
        <Column Name="Response" DataType="DT_NTEXT" />
      </OutputColumns>
      <InputColumns>
        <Column Name="IssueIdOrKey" Label="Id" MapToParam="True" DataType="DT_WSTR" Key="True" />
      </InputColumns>
    </EndPoint>

    <!-- 
      ========
      WORKLOGS (Lookup by Id not possible due to 2 params required so use child endpoint technique)
      ========
-->
    <EndPoint Name="get_worklogs" Label="Read Worklogs" Template="IssuesTemplate" 
              Method="GET" Filter="$.issues[*]">
      <Params>
        <Param Name="Key"
              Label="Issue Key(s) or Ids - Comma Separated (PRJA-10,PRJA-13)"
              IsKey="True"
              ReadAs="IssueId"
              Key="jql"
              Required="False"
              Type="Query"
              VisibleIf="SearchBy==Key"
              Functions="{$rows$}"
              ValueTemplate="Key in ({$value$})"
              Desc="Use comma separated IDs or Keys for Issues. 1000 ids max or JIRA internal limit for Payload."
              />
      </Params>
      <OutputColumns>
        <Column Name="issueId" Label="IssueId" DataType="DT_WSTR" Length="20" />
        <Column Name="p1_key" Label="IssueKey" DataType="DT_WSTR" Length="50" />
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="20" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="P_startAt" Label="StartAt" DataType="DT_I4" />
        <Column Name="P_maxResults" Label="MaxResults" DataType="DT_I4" />
        <Column Name="P_total" Label="Total" DataType="DT_I8" />
        <Column Name="author.self" Label="AuthorSelf" DataType="DT_WSTR" Length="200" />
        <Column Name="author.accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="150" />
        <Column Name="author.emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="200" />
        <Column Name="author.displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="author.active" Label="AuthorIsActive" DataType="DT_BOOL" />
        <Column Name="author.timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="100" />
        <Column Name="author.accountType" Label="AuthorAccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="comment.content" Label="CommentFormatted" DataType="DT_NTEXT"/>
        <Column Name="comment.content" Label="Comment" 
                DataType="DT_NTEXT" 
                Functions="[$1]|~|$..content[*].text|~| ,FUN_JSON_TO_TEXT" 
                Desc="Join formatted text blocks using space separator (new lines will be lost)"/>
        <Column Name="updateAuthor.self" Label="UpdateAuthorSelf" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.accountId" Label="UpdateAuthorAccountId" DataType="DT_WSTR" Length="200" />
        <Column Name="updateAuthor.emailAddress" Label="UpdateAuthorEmailAddress" DataType="DT_WSTR" Length="200" />
        <Column Name="updateAuthor.displayName" Label="UpdateAuthorDisplayName" DataType="DT_WSTR" Length="200" />
        <Column Name="updateAuthor.active" Label="UpdateAuthorActive" DataType="DT_BOOL" />
        <Column Name="updateAuthor.timeZone" Label="UpdateAuthorTimeZone" DataType="DT_WSTR" Length="80" />
        <Column Name="updateAuthor.accountType" Label="UpdateAuthorAccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="created" Label="Created" DataType="DT_DBTIMESTAMP" />
        <Column Name="updated" Label="Updated" DataType="DT_DBTIMESTAMP" />
        <Column Name="started" Label="Started" DataType="DT_DBTIMESTAMP" />
        <Column Name="timeSpent" Label="TimeSpent" DataType="DT_WSTR" Length="50" />
        <Column Name="timeSpentSeconds" Label="TimeSpentInSeconds" DataType="DT_I8" />
        <Column Name="author.avatarUrls.48x48" Label="AuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.24x24" Label="AuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.16x16" Label="AuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.32x32" Label="AuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.48x48" Label="UpdateAuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.24x24" Label="UpdateAuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.16x16" Label="UpdateAuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.32x32" Label="UpdateAuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
      </OutputColumns>
      <EndPoint Name="get_issue_worklogs" Label="Read Worklogs" 
                Url="/issue/[$parent.id$]/worklog" Method="GET" 
                Filter="$.worklogs[*]" IncludeParentColumns="True">
      </EndPoint>
    </EndPoint>

    <!-- CREATE WORKLOGS  -->
    <EndPoint Template="WorklogTemplate" Name="create_worklog" Label="Create Worklog" Url="/issue/[$IssueIdOrKey$]/worklog" Method="POST"
              ResponseFormat="Json"
              JsonRowFormat="Multicontent"
              ContentType="application/json"
              Body="{$rows$}">
    </EndPoint>

    <!-- UPDATE WORKLOGS  -->
    <EndPoint Template="WorklogTemplate" Name="update_worklog" Label="Update Worklog" Url="/issue/[$IssueIdOrKey$]/worklog/[$WorklogId$]" Method="PUT"
              ResponseFormat="Json"
              JsonRowFormat="Multicontent"
              ContentType="application/json"
              Body="{$rows$}">
      <Params>
        <Param Name="IssueIdOrKey" Type="Placeholder" />
        <Param Name="WorklogId" Type="Placeholder" />
		<Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
	  <InputColumns>
		<Column Name="WorklogId" Label="Id" MapToParam="True" Key="True" DataType="DT_STR" Length="50" ExcludeFromRowMap="True"  />
	  </InputColumns>
    </EndPoint>

    <!-- DELETE WORKLOGS  -->
    <EndPoint Name="delete_worklogs" Label="Delete Worklog" Url="/issue/[$IssueIdOrKey$]/worklog/[$WorklogId$]" Method="DELETE"
              ResponseFormat="Json" >
      <Params>
        <Param Name="IssueIdOrKey" Type="Placeholder" />
        <Param Name="WorklogId" Type="Placeholder" />
		<Param Name="ContinueOn404Error" Key="ContineOn404Error" Label="Continue On 404 Error (When record not found)" Type="Property" Value="False" />
      </Params>
      <OutputColumns>
        <Column Name="Response" DataType="DT_NTEXT" />
      </OutputColumns>
      <InputColumns>
        <Column Name="WorklogId" Label="Id" DataType="DT_WSTR" MapToParam="True" Key="True" />
      </InputColumns>	  
    </EndPoint>


    <!-- 
      ========
      COMMENTS (Lookup by Id not possible due to 2 params required so use child endpoint technique)
      ========
-->
    <EndPoint Name="get_comments" Label="Read Comments" Template="IssuesTemplate" 
              Url="/search?startAt=0&amp;maxResults=50" Method="GET" Filter="$.issues[*]">
      <Params>
        <Param Name="Key"
              Label="Issue Key(s) or Ids - Comma Separated (PRJA-10,PRJA-13)"
              IsKey="True"
              ReadAs="IssueId"
              Key="jql"
              Required="False"
              Type="Query"
              VisibleIf="SearchBy==Key"
              Functions="{$rows$}"
              ValueTemplate="Key in ({$value$})"
              Desc="Use comma separated IDs or Keys for Issues. 1000 ids max or JIRA internal limit for Payload."
              />
      </Params>
      <OutputColumns>
        <Column Name="p1_id" Label="IssueId" DataType="DT_WSTR" Length="20" />
        <Column Name="p1_key" Label="IssueKey" DataType="DT_WSTR" Length="50" />
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="20" />
        <Column Name="created" Label="Created" DataType="DT_DBTIMESTAMP" />
        <Column Name="updated" Label="Updated" DataType="DT_DBTIMESTAMP" />
        <Column Name="self" Label="Self" DataType="DT_WSTR" Length="150" />
        <Column Name="body.type" Label="BodyType" DataType="DT_WSTR" Length="50" />
        <Column Name="body.content" Label="BodyContent" DataType="DT_NTEXT" />
        <Column Name="body.content" Label="BodyContentText" DataType="DT_NTEXT" Functions="[$1]|~|$..content[*].text|~| ,FUN_JSON_TO_TEXT" Desc="Join formatted text blocks using space separator (new lines will be lost)" />
        <Column Name="body.version" Label="BodyVersion" DataType="DT_NUMERIC" />
        <Column Name="author.self" Label="AuthorSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="author.accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="100" />
        <Column Name="author.emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="author.avatarUrls.48x48" Label="AuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.24x24" Label="AuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.16x16" Label="AuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.32x32" Label="AuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="author.displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="100" />
        <Column Name="author.active" Label="AuthorActive" DataType="DT_BOOL" />
        <Column Name="author.timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="100" />
        <Column Name="author.accountType" Label="AuthorAccountType" DataType="DT_WSTR" Length="50" />
        <Column Name="updateAuthor.self" Label="UpdateAuthorSelf" DataType="DT_WSTR" Length="150" />
        <Column Name="updateAuthor.accountId" Label="UpdateAuthorAccountId" DataType="DT_WSTR" Length="50" />
        <Column Name="updateAuthor.emailAddress" Label="UpdateAuthorEmailAddress" DataType="DT_WSTR" Length="100" />
        <Column Name="updateAuthor.avatarUrls.48x48" Label="UpdateAuthorAvatarUrls48x48" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.24x24" Label="UpdateAuthorAvatarUrls24x24" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.16x16" Label="UpdateAuthorAvatarUrls16x16" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.avatarUrls.32x32" Label="UpdateAuthorAvatarUrls32x32" DataType="DT_WSTR" Length="500" />
        <Column Name="updateAuthor.displayName" Label="UpdateAuthorDisplayName" DataType="DT_WSTR" Length="100" />
        <Column Name="updateAuthor.active" Label="UpdateAuthorActive" DataType="DT_BOOL" />
        <Column Name="updateAuthor.timeZone" Label="UpdateAuthorTimeZone" DataType="DT_WSTR" Length="44" />
        <Column Name="updateAuthor.accountType" Label="UpdateAuthorAccountType" DataType="DT_WSTR" Length="36" />
        <Column Name="jsdPublic" DataType="DT_BOOL" />
      </OutputColumns>
      <EndPoint Name="get_issue_comments" Url="/issue/[$parent.key$]/comment" Method="GET" Filter="$.comments[*]">
      </EndPoint>
    </EndPoint>

    <!-- =====================
               Get changelogs 
      ====================== -->
    <EndPoint Name="get_changelogs"
              Label="Read Changelogs"
              Desc="Returns a paginated list of all changelogs for an issue sorted by date, starting from the oldest. OAuth scopes required: read:issue-meta:jira, read:avatar:jira, read:issue.changelog:jira"
              Url="/issue/[$IssueIdOrKey$]/changelog?startAt=0&amp;maxResults=50"
              Method="GET"
              Filter="$.values[*]">
      <Params>
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />
        <Param Name="IssueIdOrKey" Label="IssueId Or Key" Type="Placeholder" Required="True" />
      </Params>
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="200" />
        <Column Name="author.self" Label="AuthorSelfURL" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="200" />
        <Column Name="author.emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.active" Label="Is AuthorActive" DataType="DT_BOOL" />
        <Column Name="author.timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="200" />
        <Column Name="created" Label="CreatedDateTime" DataType="DT_DBTIMESTAMP" />
        <Column Name="items" Label="Items" DataType="DT_WSTR" Length="4000" />
      </OutputColumns>
    </EndPoint>

    <!-- =====================
               Get changelog details 
      ====================== -->
    <EndPoint Name="get_changelog_details"
              Label="Read Changelog Details"
              Desc="Returns a paginated list of all changelogs and fields updated for an issue sorted by date, starting from the oldest. OAuth scopes required: read:issue-meta:jira, read:avatar:jira, read:issue.changelog:jira"
              Url="/issue/[$IssueIdOrKey$]/changelog?startAt=0&amp;maxResults=50"
              Method="GET"
              Filter="$.values[*].items[*]" 
              IncludeParentColumns="True" >
      <Params>
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />
        <Param Name="IssueIdOrKey" Label="IssueId Or Key" Type="Placeholder" Required="True" />
      </Params>
      <OutputColumns>
        <Column Name="P_values_id" Label="Id" DataType="DT_WSTR" Length="200" />
        <Column Name="P_values_author_self" Label="AuthorSelfURL" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="200" />
        <Column Name="P_values_author_emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="500" />
        <Column Name="P_values_author_avatarUrls_48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_avatarUrls_24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_avatarUrls_16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_avatarUrls_32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="1000" />
        <Column Name="P_values_author_active" Label="IsAuthorActive" DataType="DT_BOOL" />
        <Column Name="P_values_author_timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="200" />
        <Column Name="P_values_created" Label="CreatedDateTime" DataType="DT_DBTIMESTAMP" />
        <Column Name="field" Label="Field" DataType="DT_WSTR" Length="255" />
        <Column Name="fieldId" Label="FieldId" DataType="DT_WSTR" Length="255" />
        <Column Name="fieldtype" Label="FieldType" DataType="DT_WSTR" Length="255" />
        <Column Name="from" Label="From" DataType="DT_WSTR" Length="4000" />
        <Column Name="fromString" Label="FromString" DataType="DT_WSTR" Length="4000" />
        <Column Name="to" Label="To" DataType="DT_WSTR" Length="4000" />
        <Column Name="toString" Label="ToString" DataType="DT_WSTR" Length="4000" />
        
      </OutputColumns>
    </EndPoint>
    
    <!-- =====================
              Get changelogs by IDs
      ====================== -->
    <EndPoint Name="get_changelogs_by_ids"
              Label="Read Changelogs by IDs"
              Desc="Returns changelogs for an issue specified by a list of changelog IDs. OAuth scopes required: read:issue-meta:jira, read:avatar:jira, read:issue.changelog:jira"
              Url="/issue/[$IssueIdOrKey$]/changelog/list"
              Method="POST"
              Body="{&quot;changelogIds&quot;:[[$ChangeLogIds$]]}"
              Filter="$.histories[*]"
              ContentType="application/json"
      >
      <Params>
        <!--<Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />-->
        <Param Name="IssueIdOrKey" Label="IssueId Or Key" Type="Placeholder" Required="True" />
        <Param Name="ChangeLogIds" Label="Comma Separated ChangeLog Ids" Type="Placeholder" Required="True" />
      </Params>
      <OutputColumns>
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="200" />
        <Column Name="author.self" Label="AuthorSelfURL" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.accountId" Label="AuthorAccountId" DataType="DT_WSTR" Length="200" />
        <Column Name="author.emailAddress" Label="AuthorEmailAddress" DataType="DT_WSTR" Length="500" />
        <Column Name="author.avatarUrls.48x48" Label="AvatarUrls48x48" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.24x24" Label="AvatarUrls24x24" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.16x16" Label="AvatarUrls16x16" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.avatarUrls.32x32" Label="AvatarUrls32x32" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.displayName" Label="AuthorDisplayName" DataType="DT_WSTR" Length="1000" />
        <Column Name="author.active" Label="IsAuthorActive" DataType="DT_BOOL" />
        <Column Name="author.timeZone" Label="AuthorTimeZone" DataType="DT_WSTR" Length="200" />
        <Column Name="created" Label="CreatedDateTime" DataType="DT_DBTIMESTAMP" />
        <Column Name="items" Label="Items" DataType="DT_WSTR" Length="4000" />
      </OutputColumns>
    </EndPoint>
	
	<!-- =====================
               Get custom field contexts
      ====================== -->
    <EndPoint Name="get_custom_field_contexts"
              Label="Get custom field contexts"
              Desc="Returns a paginated list list of contexts for a custom field. OAuth scopes required: read:field:jira, read:custom-field-contextual-configuration:jira"
              Url="/field/[$FieldId$]/context?startAt=0&amp;maxResults=50"
              Method="GET"
              Filter="$.values[*]" 
              IncludeParentColumns="True" >
      <Params>
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />
        <Param Name="FieldId" Label="FieldId" DataType="DT_WSTR" Length="100"  Required="True"/>
      </Params>
      <OutputColumns>
        <Column Name="P_isLast" Label="IsLast" DataType="DT_BOOL" />
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="100" />
		<Column Name="name" Label="Name" DataType="DT_WSTR" Length="1000" />
		<Column Name="description" Label="Description" DataType="DT_WSTR" Length="4000" />
		<Column Name="isGlobalContext" Label="IsGlobalContext" DataType="DT_BOOL" />
		<Column Name="isAnyIssueType" Label="IsAnyIssueType" DataType="DT_BOOL" />
      </OutputColumns>
    </EndPoint>
	
	<!-- =====================
               Get custom field options (context)
      ====================== -->
    <EndPoint Name="get_custom_field_option_for_context"
              Label="Get custom field context options"
              Desc="Returns a paginated list of all custom field option for a context. Options are returned first then cascading options, in the order they display in Jira. OAuth scopes required: read:field.option:jira"
              Url="/field/[$FieldId$]/context/[$ContextId$]/option?startAt=0&amp;maxResults=50"
              Method="GET"
              Filter="$.values[*]" 
              IncludeParentColumns="True" >
      <Params>
        <Param Name="PagingMode" Type="Property" Value="1" />
        <Param Name="PagingByUrlAttributeName" Type="Property" Value="startAt" />
        <Param Name="PagingIncrementBy" Type="Property" Value="50" />
        <Param Name="FieldId" Label="FieldId" DataType="DT_WSTR" Length="100"  Required="True"/>
		<Param Name="ContextId" Label="ContextId" DataType="DT_WSTR" Length="100"  Required="True"/>
      </Params>
      <OutputColumns>
        <Column Name="P_isLast" Label="IsLast" DataType="DT_BOOL" />
        <Column Name="id" Label="Id" DataType="DT_WSTR" Length="100" />
		<Column Name="value" Label="Value" DataType="DT_WSTR" Length="1000" />
		<Column Name="disabled" Label="Isdisabled" DataType="DT_BOOL" />
		<Column Name="optionId" Label="OptionId" DataType="DT_WSTR" Length="1000" />
      </OutputColumns>
    </EndPoint>

  </EndPoints>

  <Tables>
    <Table Name="Fields" SelectEndPoint="get_fields" />
    <Table Name="Projects" SelectEndPoint="get_projects" InsertEndPoint="create_project" 
           UpdateEndPoint="upsert_project" UpsertEndPoint="upsert_project" DeleteEndPoint="delete_project"/>
    <Table Name="Users" SelectEndPoint="get_users" InsertEndPoint="create_user" DeleteEndPoint="delete_user" />
    <Table Name="IssueTypes" SelectEndPoint="get_types" />
    <Table Name="Issues" SelectEndPoint="get_issues" LookupEndPoint="get_issues" InsertEndPoint="create_issues" UpdateEndPoint="update_issue" DeleteEndPoint="delete_issue" />
    <Table Name="Worklogs" SelectEndPoint="get_worklogs" InsertEndPoint="create_worklog" 
           UpdateEndPoint="update_worklog" DeleteEndPoint="delete_worklogs" LookupEndPoint="get_worklogs"/>
    <Table Name="Comments" SelectEndPoint="get_comments" LookupEndPoint="get_comments" />
  </Tables>
  <!-- FIELDS -->
  <Examples>
    <Example Group="ODBC" Label="List issues" Code="SELECT * FROM Issues" Desc="Lists all issues" ></Example>
    
    <Example Group="ODBC" Label="List a single issue by Id" Code="select * from Issues Where Id=10001" ></Example>
    <Example Group="ODBC" Label="List a single issue by Key" Code="SELECT * FROM Issues WITH(Key='CS-1')" Desc="List a single issue by Key or Numeric Id." ></Example>
	
    <Example Group="ODBC" Label="List multiple issues by Id or Key" 
              Code="SELECT * FROM Issues WITH(Key='CS-1, CS-2, 10003, 10004')" Desc="List multiple issues by comma separated Key(s) or Numeric Id(s)." ></Example>
    <Example Group="ODBC" Label="List all issues for a specific project"
              Code="SELECT * FROM Issues WITH(Project='CS')" Desc="List all issues for a specified project code." ></Example>

    <Example Group="ODBC" Label="Search issues using Advanced JQL query expression" Desc="List issues using JQL query expression">
      <Code>
        <![CDATA[SELECT * FROM Issues WITH (Jql='status IN (Done, Closed) AND created > -5d' )
/*
Useful links:
  https://support.atlassian.com/jira-work-management/docs/jql-fields/
  https://www.atlassian.com/software/jira/guides/jql/tutorials#advanced-search
  https://www.atlassian.com/blog/jira/jql-the-most-flexible-way-to-search-jira-14
  
Other Possible JQL expressions:

Ids (IN):       key IN(10001, 10002, 10003);
Keys (IN):       key IN(CS-1, CS-2, CS-3);
Projects (IN):       project IN(PROJ1, PROJ2, PROJ3);
Status (EQUAL):       status='Done';
Date (Expression 1):       created >=-5d;
Date (Expression 2):       created >=startOfMonth() AND created <=now();
Date (Expression 3):       created >=startOfYear() AND created <=startOfDay();
Date (Static):       created >= 2008/12/31;
Date (Static with time):       created >= 2008/12/31 23:59;
Project and Status (AND + IN):       project=CS AND status NOT IN ('Done', 'Open', 'Closed');
Assignee and Created Date:    assignee is NOT EMPTY and created < -1d;
Text (Contains - Fuzzy):       Summary ~ 'some words' OR description ~ 'some words';
Text (Contains - Fuzzy Wildcard):       Summary ~ 'some*' OR description ~ 'some*';
Text (Contains - Exact):       Summary ~ '\"exact words\"' OR description ~ '\"exact words\"';
Text (Does Not Contain - Fuzzy):       Summary !~ 'some words' OR description !~ 'some words';
Empty OR Null:   fixVersion is empty OR fixVersion is null;
Is Not Empty OR Is Not Null:    fixVersion is not empty OR fixVersion is not null;
WAS Operator (previous value):       status WAS "Resolved" BY (jsmith,srogen) BEFORE "2019/02/02";
WAS IN Operator:   status WAS IN ("Resolved", "In Progress");
WAS NOT IN Operator:    status WAS NOT IN ("Resolved", "In Progress");
WAS + BY + DURING (date range):       status WAS "Resolved" BY (jsmith,srogen) DURING("2019/02/02", "2020/02/02");
CHANGED operator:    assignee CHANGED;
CHANGED operator (multiple):       status CHANGED FROM "In Progress" TO "Open"

*/        
        
        ]]>
      </Code>
    </Example>

    <Example Group="ODBC" Label="INSERT Issue" Desc="Inserts a single issue to a particular project">
      <Code>
        <![CDATA[INSERT INTO Issues(ProjectKey, IssueTypeName, Summary, Description)
VALUES('SMP', 'Task', 'My ticket inserted through the API', 'A description about an issue')
WITH (Output=1)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="UPDATE Issue" Desc="Updates an issue">
      <Code>
        <![CDATA[UPDATE Issues
SET Summary = 'This is my summary'
   ,Description = 'Lot''s of stuff to describe'
   ,Labels = '[ "bugfix" ]'
   ,DueDate = '2029-10-10'
--WHERE Id=1234   
--WHERE Id='ISSKEY'   
WITH (
	IssueIdOrKey='ISSKEY', --or use Id in where clause 
	Output=1,
	NotifyUsers=0,
	OverrideScreenSecurity=0,
	OverrideEditableFlag=0,
	ContinueOn404Error=0
)']]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="UPDATE / Insert Issue with Custom Fields" Desc="Updates or Insert an issue with custom fields of various types (dropdown, radio, textarea .. so on)">
      <Code>
        <![CDATA[UPDATE Issues
SET customfield_10050='[{"value":"AAA"},{"value":"BBB"}]'	--CUSTOM Checkboxes (Must use Raw JSON)
,customfield_10051='2020-12-31'	--CUSTOM Date
,customfield_10052='2020-12-31T23:59:59'	--CUSTOM DateTime

--Custom Dropdown / Radio fields
,customfield_10048_value='BBB'	--CUSTOM Dropdown (Using value - i.e. item label)
--OR--
--,customfield_10048_id='10022'	--CUSTOM Dropdown (Using id - i.e. item id)
--OR
--,customfield_10048='{"value":"BBB"}'	--CUSTOM Dropdown (Using Raw value)

,customfield_10053='["bugfix","test"]'	--CUSTOM Labels (Must use Raw JSON)
,customfield_10057='[{"value":"AAA"},{"value":"BBB"}]'	--CUSTOM Listbox Multiselect (Must use Raw JSON)
,customfield_10049=123455555.123	--CUSTOM Number
,customfield_10054_text='Long string...line-1 
	Long string... line-2 
	Long string... line-3'	--CUSTOM Paragraph

,customfield_10055_value='BBB'	--CUSTOM Radio
--OR
--,customfield_10055_id='10023'	--CUSTOM Radio

,customfield_10058='https://zappysys.com'	--CUSTOM Url
,customfield_10059='{"accountId":"5dd64082af96bc0efbe55103","displayName":"System"}'	--CUSTOM User --accountId=5dd64082af96bc0efbe55103
,customfield_10060='Custom text single line'	--CUSTOM text single line 
--WHERE Id=10000
WITH (
	IssueIdOrKey='ISSKEY', --or use Id in where clause 
	Output=1,
	NotifyUsers=0,
	OverrideScreenSecurity=0,
	OverrideEditableFlag=0,
	ContinueOn404Error=0
)

--For INSERT use same values with same fields like below. For Insert you do not have to specify Id or Key
--INSERT INTO Issues(ProjectKey, IssueTypeName, Summary, Description, customfield_10050,....., customfield_10060) 
--VALUES ('SMP', 'Task', 'My ticket inserted through the API', 'A description about an issue', '[{"value":"AAA"},{"value":"BBB"}]' ,... 'Custom text single line')

']]>
      </Code>
    </Example>	
	

<Example Group="ODBC" Label="UPDATE multiple Issues matching with JQL search query" Desc="Updates multiple issues which match with certain condition (JQL). Adding Where 1=1 or some other WHERE condition invokes Lookup endpoint (refer to other example to learn about JQL - see Search issues using Advanced JQL query expression)">
      <Code>
        <![CDATA[UPDATE Issues
SET Summary = 'This is done on <<fun_now>>'
Where 1=1
WITH (jql='status=done' , ContinueOn404Error=0)
--WITH (jql='key in(10001, 10002, 10003)' , ContinueOn404Error=0)
--WITH (jql='key in(CS-1, CS-2, CS-3)', ContinueOn404Error=0)
]]>
      </Code>
    </Example>

    <Example Group="ODBC" Label="DELETE Issue" Desc="Deletes a single issue">
      <Code>
        <![CDATA[DELETE FROM Issues
WITH (IssueIdOrKey='10020', OUTPUT=1, ContinueOn404Error=0)]]>
      </Code>
    </Example>

<Example Group="ODBC" Label="DELETE multiple Issues matching with JQL search query" Desc="Delete multiple issues which match with certain condition (JQL). Adding Where 1=1 or some other WHERE condition invokes Lookup endpoint (refer to other example to learn about JQL - see Search issues using Advanced JQL query expression)">
      <Code>
        <![CDATA[DELETE FROM Issues
Where 1=1
WITH (jql='status=done' , ContinueOn404Error=0)
--WITH (jql='key in(10001, 10002, 10003)' , ContinueOn404Error=0)
--WITH (jql='key in(CS-1, CS-2, CS-3)', ContinueOn404Error=0)
]]>
      </Code>
    </Example>

    <Example Group="ODBC" Label="List comments for all issues" Code="SELECT * FROM Comments" 
             Desc="List comments for all issues" ></Example>
    <Example Group="ODBC" Label="List comments for a specific issue Issue Key or Id" 
             Code="SELECT * FROM Comments Where IssueId=10003 --OR WITH(Key='10003')" 
             Desc="List comments for a specific issue" ></Example>
    <Example Group="ODBC" Label="List comments for a specific issue by Key"
             Code="SELECT * FROM Comments WITH(Key='CS-1')"
             Desc="List comments for a specific issue by key" ></Example>
    
    <Example Group="ODBC" Label="List comments for issues (search by JQL)"
         Code="SELECT * FROM Comments WITH (Jql='status IN (Done, Closed) AND created > -5d' )"
         Desc="List all comments for issues returned from a JQL search expression (refer to previous example to learn about JQL - see Search issues using Advanced JQL query expression) " ></Example>
    
    <Example Group="ODBC" Label="List fields" Code="SELECT * FROM Fields" Desc="Lists all fields that are used and available in issue entity" ></Example>

    <!-- PROJECT -->
    <Example Group="ODBC" Label="List projects" Code="SELECT * FROM Projects" Desc="Lists all available projects" ></Example>

    <Example Group="ODBC" Label="List worklog entries for a specific issue by Id or Key"
             Code="SELECT * FROM Worklogs Where IssueId=10003 --WITH(Key='10003')"
             Desc="List all worklog entries for a specific issue" ></Example>
    
    <Example Group="ODBC" Label="List worklogs for issues (search by JQL)"
         Code="SELECT * FROM Worklogs WITH (Jql='status IN (Done, Closed) AND created > -5d' )"
         Desc="List all worklogs (time entries) for issues returned from a JQL search expression (refer to previous example to learn about JQL - see Search issues using Advanced JQL query expression) " ></Example>


    <Example Group="ODBC" Label="INSERT Project" Desc="Inserts a single project">
      <Code>
        <![CDATA[INSERT INTO Projects(ProjectKey, Name, ProjectTypeKey, LeadAccountId, AssigneeType)
VALUES ('TEST', 'Test Project', 'software', '70122:XXXXXXXX-XXXX-XXXX-XXXX-c5da8c98b9e2', 'PROJECT_LEAD)
WITH (Output=1)')]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="UPDATE Project" Desc="Updates a single project">
      <Code>
        <![CDATA[UPDATE Projects
SET Name = 'My Test Kanban Project'
   ,ProjectCategoryId = 1
WITH (ProjectIdOrKey = 'MYPRJCT', Output=1, ContinueOn404Error=0)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="DELETE Project" Desc="Deletes a single project">
      <Code>
        <![CDATA[DELETE FROM Projects
WITH (ProjectIdOrKey = '10020', Output=1, ContinueOn404Error=0)]]>
      </Code>
    </Example>

    <!-- USERS -->
    <Example Group="ODBC" Label="List users" Code="SELECT * FROM Users" Desc="Lists all available users" ></Example>
    <Example Group="ODBC" Label="INSERT User" Desc="Inserts a single user">
      <Code>
        <![CDATA[INSERT INTO Users(EmailAddress, DisplayName, Name, Password)
VALUES ('my@user.com', 'John Doe', 'John', 'xhedkspstdadaothoua')
WITH (OUTPUT=1)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="DELETE User" Desc="Deletes a single user">
      <Code>
        <![CDATA[DELETE FROM Users
WITH (OUTPUT=1, accountId = '547059:136095a0-XXXX-XXXX-XXXX-3e4c66f26551', ContinueOn404Error=0)]]>
      </Code>
    </Example>

    <!-- ISSUES -->



    <!-- WORKLOGS -->
    <Example Group="ODBC" Label="List worklogs" Code="SELECT * FROM Worklogs" Desc="Lists all worklogs from all issues" ></Example>
    <Example Group="ODBC" Label="INSERT Worklog" Desc="Inserts a single worklog to a particular issue">
      <Code>
        <![CDATA[INSERT INTO Worklogs(TimeSpentInSeconds, Comment, StartedAt)
      VALUES(7200,'My Comment!','2020-02-23T16:20:30.123+0000')
      WITH (IssueIdOrKey='ISSKEY-1', OUTPUT=1)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="UPDATE Worklog" Desc="Updates a worklog">
      <Code>
        <![CDATA[UPDATE Worklogs
SET TimeSpentInSeconds = 28800
   ,Comment='My Comment!'
   ,StartedAt='2020-01-23T16:20:30.123+0000'
WITH (IssueIdOrKey='MTK-1', WorklogId='123465', OUTPUT=1, ContinueOn404Error=0)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="DELETE Worklog" Desc="Deletes a single worklog of an issue">
      <Code>
        <![CDATA[DELETE FROM Worklogs
WITH (IssueIdOrKey='10020', WorklogId='123465', OUTPUT=1, ContinueOn404Error=0)]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="Update Custom Option Field (Dropdown/Radio)" Desc="This example shows how to update a custom field of an issue by Option Value or Id (Of option entry item)">
      <Code>
        <![CDATA[
--(By value)        
UPDATE Issues 
SET customfield_10048_value ='BBB' --supply value (label) of dropdown/radio
WITH (IssueIdOrKey='10020')

--OR-- (By item ID)

UPDATE Issues 
SET customfield_10048_id =10023 --supply id of dropdown/radio item
WITH (IssueIdOrKey='10020')

--OR-- (Raw id)

UPDATE Issues 
SET customfield_10048='{"id":"10023"}' --supply raw json
WITH (IssueIdOrKey='10020')

--OR--  (Raw value)
UPDATE Issues 
SET customfield_10048='{"value":"BBB"}' --supply raw json
WITH (IssueIdOrKey='10020')

--OR--  (set null)

UPDATE Issues 
SET customfield_10048 =null 
WITH (IssueIdOrKey='10020')
		]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="Update Custom Multi Select / User / Team fields (RAW Json Update)" Desc="This example shows how to update a custom field of type array or other complex fiels like user" >
      <Code>
        <![CDATA[
UPDATE Issues 
SET customfield_10048='[{"value":"AAA"}, {"value":"CCC"}]' --supply raw json
WITH (IssueIdOrKey='10020')

--OR-- 

UPDATE Issues 
SET customfield_10048 =null --set to null
WITH (IssueIdOrKey='10020')
		]]>
      </Code>
	  
    </Example>	
  </Examples>
</ApiConfig>