﻿<ConnectionManager Name="Brivo" RuntimeVersion="" Help="http://www.cozyroc.com/ssis/brivo-connection" xmlns="http://www.cozyroc.com/schema/rcm-config-1.0.xsd">
	<Service EndPoint="https://api.brivo.com/v1/api" />

	<Authentication Name="OAuth">
		<Documentation>https://apidocs.brivo.com/#oauth2-tokens</Documentation>

		<User>
			<Parameter Name="client_id">
				<Documentation>Required. Specify client_id.</Documentation>
			</Parameter>
			<Parameter Name="client_secret" Type="password">
				<Documentation>Required. Specify client_secret.</Documentation>
			</Parameter>
			<Parameter Name="redirect_uri">
				<Documentation>Required. Specify client_id.</Documentation>
			</Parameter>
			<Parameter Name="apiKey" Type="password">
				<Documentation>Required. Specify APIKey.</Documentation>
			</Parameter>
		</User>

		<Test Url="/accounts" />

		<Token Url="https://auth.brivo.com/oauth/authorize" Result="{{=response.access_token}}">
			<Parameters>
				<Parameter Name="response_type" Value="code" />
				<Parameter Name="client_id" Value="{{=token.client_id}}" />
				<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
			</Parameters>

			<Authorized Id="https://www.cozyroc.com/oauth_callback/" Result="{{=connection.execute({
				url: 'https://auth.brivo.com/oauth/token',
				method: 'POST',
				headers:{
					Auhtorization: Basic + ' ' + Base64.encode(connection.user.client_id + ':' + connection.user.client_secret),
					api-key: token.APIKey
				}
				parameters: {
					code: response.code,
					grant_type: 'authorization_code',
					redirect_uri: token.redirect_uri
				}
			})}}" />

			<Refresh Url="https://auth.brivo.com/oauth/token" Method="POST" Result="{{=response.refresh_token}}" Expiration="{{=Date.now() + (response.expires_in - 900) * 1000}}">
				<Parameters>
					<Parameter Name="grant_type" Value="refresh_token" />
					<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
					<Parameter Name="refresh_token" Value="{{=token.Refresh}}" />
				</Parameters>
			</Refresh>
		</Token>

		<Parameters>
			<Parameter Name="Authorization" Value="Bearer {{=token.Access}}" Type="HttpHeader" />
			<Parameter Name="api-key" Value="{{=connection.user.apiKey}}" Type="HttpHeader" />
		</Parameters>
	</Authentication>

	<Authentication Name="Password">
		<Documentation>https://apidocs.brivo.com/#oauth2-tokens</Documentation>

		<User>
			<Parameter Name="username">
				<Documentation>Required. Specify client_id.</Documentation>
			</Parameter>
			<Parameter Name="password" Type="password">
				<Documentation>Required. Specify client_secret.</Documentation>
			</Parameter>
			<Parameter Name="client_id">
				<Documentation>Required. Specify client_id.</Documentation>
			</Parameter>
			<Parameter Name="client_secret" Type="password">
				<Documentation>Required. Specify client_secret.</Documentation>
			</Parameter>
			<Parameter Name="apiKey">
				<Documentation>Required. Specify APIKey.</Documentation>
			</Parameter>
		</User>

		<Test Url="/accounts" />

		<Token Url="https://auth.brivo.com/oauth/token" Method="POST" Result="{{=response.access_token}}">
			<Parameters>
				<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
				<Parameter Name="grant_type" Value="password" />
				<Parameter Name="username" Value="{{=connection.user.username}}" />
				<Parameter Name="password" Value="{{=connection.user.password}}" />
			</Parameters>

			<Refresh Url="https://auth.brivo.com/oauth/token" Method="POST" Result="{{=response.refresh_token}}" Expiration="{{=Date.now() + (response.expires_in - 50) * 1000}}">
				<Parameters>
					<Parameter Name="grant_type" Value="refresh_token" />
					<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.client_id + ':' + connection.user.client_secret)}}" Type="HttpHeader" />
					<Parameter Name="refresh_token" Value="{{=token.Refresh}}" />
				</Parameters>
			</Refresh>
		</Token>

		<Parameters>
			<Parameter Name="Authorization" Value="Bearer {{=token.Access}}" Type="HttpHeader" />
			<Parameter Name="api-key" Value="{{=connection.user.apiKey}}" 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 Result="{{=response.data}}">
					<Parameters>
						<Parameter Name="offset" Value="{{=parameters.iterator}}" />
						<Parameter Name="pageSize" Value="{{=parameters.batchSize}}" />
						<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="PATCH">
					<Parameters>
						<Parameter Name="_includeUserParameters" Value="{{=parameters}}" />
						<Parameter Name="application/json" Value="{{=item}}" Type="Body" />
					</Parameters>
				</Update>

				<Delete Method="DELETE">
					<Parameters>
						<Parameter Name="_includeUserParameters" Value="{{=parameters}}" />
						<Parameter Name="application/json" Value="{{=item}}" Type="Body" />
					</Parameters>
				</Delete>
			</Resource>

		</Template>
	</Resources>
	<Script>
		<Module Name="Main">
			<![CDATA[
require('underscore');
require('base64');

]]>
		</Module>
	</Script>
</ConnectionManager>