Hubspot 데이터를 API로 갱신하기

지난번에는 Xplenty: Hubspot의 데이터를 API로 가져오는 방법에 대해 소개했지만, 이번에는 Hubspot의 API를 사용하여 Xplenty에서 Hubspot의 Contact 데이터를 갱신하는 방법에 대해 설명합니다.
이번에 사용하는 API에 관한 참고 문서:
https://legacydocs.hubspot.com/docs/methods/contacts/create_or_update

데이터 쓰기

여기서는 S3에 저장된 연락처 목록의 CSV 파일을 Hubspot으로 갱신하는 방법을 보여줍니다.

스토리지 컴포넌트(Source)를 통해, S3에서 Hubspot에 갱신 할 데이터를 가져옵니다.

thumbnail image

Select 컴포넌트에서 Curl 함수를 사용하여 리퀘스트를 정의합니다.

Select 컴포넌트 설정 화면

thumbnail image

리퀘스트 예:
https://api.hubapi.com/contacts/v1/contact/createOrUpdate/email/메일주소_필드이름/?hapikey=<API_키값>

리퀘스트 Body 예:

{
	"properties": [
		{
			"property": "firstname",
			"value": "firstname_필드이름"
		},
		{
			"property": "lastname",
			"value": "lastname_필드이름"
		},
		{
			"property": "company",
			"value": "기업명_필드이름"
		}
	]
}

위의 바디 구조를 참고하여 Xplenty의 Curl 함수를 사용한 갱신용 함수식을 만든다.
Curl(CONCAT('https://api.hubapi.com/contacts/v1/contact/createOrUpdate/email/', mail, '/?hapikey=API-키값'), 'POST', '{"content-type":"application/json"}', CONCAT('{ "properties": [{"property": "firstname","value": "',FirstName ,'" }, {"property": "lastname","value": "' ,LastName,'" },{"property": "company","value": "',Company,'" }]}') )#'status'

작성된 패키지는 다음과 같습니다.

thumbnail image

Xplenty에서 작업 실행 결과 확인

작업이 올바르게 실행되고 각 이메일 주소에 대한 요청이 성공(상태: 200)하였음을 알 수 있습니다.

thumbnail image

Hubspot쪽의 화면에서 확인하면, 작업 실행 전에 대해 데이터가 올바르게 추가/갱신되었다는 것을 확인할 수 있습니다.

작업 실행 전:

thumbnail image

작업 실행 후:

thumbnail image

변수사용이 편리

이번에는 빠른 이해를 위해 API Key나 URL을 고정값으로 세트하여 소개 했지만, 운영 편의성 측면에서는 변수사용을 추천합니다.