﻿<?xml version="1.0" encoding="utf-8"?>
<ConnectionManager Name="Reltio" RuntimeVersion="" Help="http://www.cozyroc.com/ssis/reltio-connection" xmlns="http://www.cozyroc.com/schema/rcm-config-1.0.xsd">
	<Service EndPoint="https://[environment].reltio.com/reltio/api" />

	<Authentication Name="OAuth 2 Client Credentials">
		<Documentation>https://docs.reltio.com/en/developer-resources/system-administration-apis/system-administration-apis-at-a-glance/authentication-api/obtaining-access-tokens-with-client-credentials-grant-type</Documentation>

		<User>
			<Parameter Name="client_id">
				<Documentation>Required. Specify client identifier.</Documentation>
			</Parameter>
			<Parameter Name="client_secret" Type="password">
				<Documentation>Required. Specify client secret.</Documentation>
			</Parameter>
		</User>

		<Test Url="/tasks">
			<Parameters>
				<Parameter Name="max" Value="1" Type="QueryString" />
			</Parameters>
		</Test>

		<Token Url="{{=OAuth2CC.access_token_url}}" Method="POST" Result="{{=response.access_token}}">
			<Documentation>https://docs.reltio.com/en/developer-resources/system-administration-apis/system-administration-apis-at-a-glance/authentication-api/obtaining-access-tokens-with-client-credentials-grant-type</Documentation>

			<Parameters>
				<Parameter Name="grant_type" Value="client_credentials" />
				<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
			</Parameters>

			<Refresh Url="{{=OAuth2CC.refresh_token_url}}" Method="POST" Result="{{=response.access_token}}" Expiration="{{=Date.now() + (response.expires_in - 300) * 1000}}">
				<Documentation>https://docs.reltio.com/en/developer-resources/system-administration-apis/system-administration-apis-at-a-glance/authentication-api/obtaining-access-tokens-with-client-credentials-grant-type</Documentation>

				<Parameters>
					<Parameter Name="grant_type" Value="client_credentials" />
					<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
				</Parameters>
			</Refresh>
		</Token>

		<Parameters>
			<Parameter Name="Authorization" Value="Bearer {{=token.Access}}" Type="HttpHeader" />
		</Parameters>
	</Authentication>

	<Resources>
		<Template>
			<Field Name="ShortText" DataType="DT_WSTR" Length="255" />
			<Field Name="LongText" DataType="DT_WSTR" Length="1000" />
			<Field Name="DateTime" DataType="DT_DBTIMESTAMP" />
			<Field Name="Date" DataType="DT_DBDATE" />

			<Resource Name="Base">
				<Read>
					<Parameters>
						<Parameter Name="offset" Value="{{=parameters.batchSize}}" />
						<Parameter Name="max" Value="{{=parameters.iterator}}" />
						<Parameter Name="_includeUserParameters" Value="{{=parameters}}" />
					</Parameters>

					<Iterator>
						<Next Value="{{=parseInt(parameters.iterator || 0) + parameters.batchSize}}" />
					</Iterator>
				</Read>
				
				<Create Method="POST">
					<Parameters>
						<Parameter Name="_includeUserParameters" Value="{{=parameters}}" />
						<Parameter Name="application/json" Value="{{=item}}" Type="Body" />
					</Parameters>
				</Create>
				
				<Update Method="PUT">
					<Parameters>
						<Parameter Name="_includeUserParameters" Value="{{=parameters}}" />
						<Parameter Name="application/json" Value="{{=item}}" Type="Body" />
					</Parameters>
				</Update>
				
				<Delete Method="DELETE" />
			</Resource>
		</Template>
	</Resources>
	<Script>
		<Module Name="Main">
			<![CDATA[
require('underscore');
require('base64');

		]]>
		</Module>
		<Module Name="OAuth 2 Client Credentials">
			<![CDATA[
// Spec: https://datatracker.ietf.org/doc/html/rfc6749#section-1.3.4
var OAuth2CC = {
	access_token_url: 'https://auth.reltio.com/oauth/token', // required. The endpoint of the authorization server to get the access token. 
	refresh_token_url: 'https://auth.reltio.com/oauth/token', // required if the authentication needs to support renewing access tokens.
};
]]>
		</Module>
	</Script>
</ConnectionManager>