<?xml version="1.0" encoding="utf-8"?>
<!--
	BambooHR REST connection manager definitions.
	Copyright © 2006-2022 COZYROC LLC. All rights reserved.
-->
<ConnectionManager Name="BambooHR" RuntimeVersion="" Help="http://www.cozyroc.com/ssis/bamboohr-connection" xmlns="http://www.cozyroc.com/schema/rcm-config-1.0.xsd">
	<Service EndPoint="https://api.bamboohr.com/api/gateway.php/[companyDomain]/v1" />

	<Authentication Name="OAuth">
		<Documentation>https://documentation.bamboohr.com/page/single-sign-on-sso-with-openid-connect</Documentation>

		<User>
			<Parameter Name="client_id">
				<Documentation>Required. Specify application client id.</Documentation>
			</Parameter>
			<Parameter Name="client_secret" Type="password">
				<Documentation>Required. Specify application client secret.</Documentation>
			</Parameter>
			<Parameter Name="company">
				<Documentation>Required. Specify a unique subdomain {company}.</Documentation>
			</Parameter>
			<Parameter Name="redirect_uri" Default="https://www.cozyroc.com/oauth_callback">
				<Documentation>Required. Specify redirect uri you have setup during creation of app.</Documentation>
			</Parameter>
			<Parameter Name="scope" Default="openid email">
				<Documentation>Required. Specify desireable scopes.</Documentation>
			</Parameter>
		</User>

		<Test Url="https://{{=token.company}}.bamboohr.com/token.php?request=userInfo" Method="POST" />

		<Token Url="https://{{=token.company}}.bamboohr.com/authorize.php" Result="{{=response.access_token}}">
			<Documentation>https://documentation.bamboohr.com/page/single-sign-on-sso-with-openid-connect#auth-url</Documentation>

			<Parameters>
				<Parameter Name="request" Value="authorization" />
				<Parameter Name="state" Value="{{=Math.random()}}" />
				<Parameter Name="response_type" Value="code" />
				<Parameter Name="scope" Value="{{=token.scope}}" />
				<Parameter Name="client_id" Value="{{=token.client_id}}" />
				<Parameter Name="redirect_uri" Value="{{=token.redirect_uri}}" />
			</Parameters>

			<Authorized Id="https://www.cozyroc.com/oauth_callback" Result="{{=connection.execute({
				url: 'https://' + token.company + '.bamboohr.com/token.php',
				method: 'POST',
				query: { request: 'token' },
				parameters: {
					grant_type: 'authorization_code',
					code: response.code,
					redirect_uri: token.redirect_uri
					client_id: token.client_id,
					client_secret: token.client_secret,
					scope: token.scope
			} })}}" />
		</Token>

		<Parameters>
			<Parameter Name="Authorization" Value="Bearer {{=token.Access}}" Type="HttpHeader" />
		</Parameters>
	</Authentication>

	<Authentication Name="APIKey">
		<Documentation>https://documentation.bamboohr.com/docs#section-authentication</Documentation>

		<User>
			<Parameter Name="APIKey">
				<Documentation>Required. Specify the api_key.</Documentation>
			</Parameter>
		</User>

		<Test Url="https://{{=token.company}}.bamboohr.com/token.php?request=userInfo" Method="POST" />

		<Parameters>
			<Parameter Name="Authorization" Value="Basic {{=Base64.encode(connection.user.APIKey + ':' + Math.random() )}}" 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="_includeUserParameters" Value="{{=parameters}}" />
					</Parameters>
				</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">
					<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('Uri');

]]>
		</Module>
	</Script>
</ConnectionManager>