구글 시트에 새로운 데이터가 추가되면 슬랙 채널 메시지로 알림을 받아볼 수 있는 기능을 구현해보자. 슬랙의 추가 기능인 인커밍 웹훅(Incoming Webhook)과 구글 시트의 추가 기능인 앱스 스크립트(Apps Script)를 활용하면 이와 같은 기능을 쉽게 구현할 수 있다. 단, 인커밍 웹훅을 앱스 스크립트와 직접 연동해도 되지만, REST API 서버를 같이 사용해도 좋다. 이 설명에서는 FastAPI를 이용해 구현한 API 서버를 활용할 것이다.
슬랙 인커밍 웹훅(Slack Incoming Webhook)
슬랙 인커밍 웹훅(Slack Incoming Webhook)은 외부에서 REST API 요청 시 메시지를 특정 슬랙 채널에 전송할 수 있는 기능이다. 이 기능을 사용하려면 슬랙 앱(Slack App)을 만들고 이를 슬랙 워크스페이스에 설치해야 한다. 슬랙 앱 생성, 인커밍 웹훅 설정 그리고 포스트맨(Postman)을 이용한 테스트를 진행해보자.
슬랙 앱(Slack App) 생성
슬랙 앱(https://api.slack.com/apps) 접속 후 로그인한다. Your Apps에서 Create New App 버튼을 클릭한다.
data:image/s3,"s3://crabby-images/38cbd/38cbd0f306441d7922eab99357d5e74cfba2623b" alt=""
From scratch를 클릭한다.
data:image/s3,"s3://crabby-images/f9496/f9496752f00f680fc3538e1507f7521dfe6450f6" alt=""
앱 이름을 작성하고, 슬랙 앱을 설치할 워크스페이스를 선택 후 Create App 버튼을 클릭한다.
data:image/s3,"s3://crabby-images/63263/6326355c3c7b370f0f5eb2d1d27e6cc81672598a" alt=""
좌측 메뉴에서 App Home을 클릭하고, Your Apps’s Presence in Slack에서 App Display Name의 Edit 버튼을 클릭한다.
data:image/s3,"s3://crabby-images/309ef/309ef0f369fca26cbb41f86da99648a77159005e" alt=""
봇 이름과 유저명 기본값을 입력하고 Add 버튼을 클릭한다.
data:image/s3,"s3://crabby-images/0be28/0be287031d8d9fd5b5810d0cc547e8ff16cd2f02" alt=""
인커밍 웹훅 설정
좌측 메뉴에서 Incoming Webhooks를 클릭하고, Activate Incoming Webhooks를 활성화(On)한다.
data:image/s3,"s3://crabby-images/db76c/db76c1f01f2389b8fc529efc09db170dd64fd4f7" alt=""
화면 하단의 Webhook URLs for Your Workspace에서 Add New Webhook to Workspace를 클릭한다.
data:image/s3,"s3://crabby-images/ed579/ed5796a50a3c542bb8769ccffb106aed0ee1a156" alt=""
슬랙 앱을 추가할 채널을 선택한 후 허용 버튼을 클릭한다.
data:image/s3,"s3://crabby-images/9e114/9e114dddd1b258ac010f67937aff1a14a815dfb2" alt=""
Webhook URL을 복사한다.
data:image/s3,"s3://crabby-images/9b966/9b966b5d4606439ca42595a8acdc4a3a779bd052" alt=""
포스트맨(Postman)으로 슬랙 인커밍 웹훅 테스트
data:image/s3,"s3://crabby-images/8fc83/8fc83947d763b559c838b2c0511b37c099002f8e" alt=""
data:image/s3,"s3://crabby-images/ddece/ddece4c81adbd6c5a9764562e73295d28b052935" alt=""
data:image/s3,"s3://crabby-images/2f371/2f371bfb4c2528d33ac6d527a9916c1a300dc5aa" alt=""
FastAPI
아래와 같이 FastAPI를 이용해 간단한 API를 구현한다. 이 API는 구글시트에 새 데이터가 추가될 경우 호출된다. API 호출 시 구글시트에 추가된 데이터를 넘겨받아 슬랙 인커밍 웹훅 호출 시 이 값들을 적절히 가공해서 넘겨주는 역할을 한다. 자세한 API 작성 및 구동 방법은 설명을 생략한다.
import requests
from fastapi import FastAPI, HTTPException, Request
@router.post("/slack")
async def notice_new_order(request: Request):
URL = "https://<Incoming Webhook URL>"
data = await request.json()
data = data['data']
params = {
"이름": data.get("이름"),
"전화번호": data.get("전화번호"),
"이메일": data.get("이메일"),
}
message = f"*구글시트 새 데이터 추가 알림\\n\\n"
for key, value in params.items():
message += f"- {key}: *{value}*\\n"
headers = {"Content-Type": "application/json"}
payload = {"text": message}
response = requests.post(URL, headers=headers, json=payload)
return {"status": "success", "message": "Data processed successfully"}
구글 시트(Google Sheet)
구글 시트에 새로운 데이터가 추가되면 자동으로 슬랙 알림이 되게 설정해보자. 이 과정에서 구글 시트의 확장 프로그램인 앱스 스크립트(Apps Script)를 이용할 것이다.
Apps Script 실행
구글 시트에 이름, 전화번호, 이메일과 같이 적당한 컬럼명을 입력한다. 그 다음 메뉴에서 확장 프로그램 – Apps Script를 선택한다.
data:image/s3,"s3://crabby-images/0e99e/0e99eeaaada7600e765cfc0c73aed4c102d4af14" alt=""
자동화 스크립트(Script) 작성
다음과 같이 코드를 작성한다.
data:image/s3,"s3://crabby-images/58bb6/58bb6f1d685e941129b50ecdba6541f2d0994a49" alt=""
let url = "<API 엔드포인트 URL>/slack";
function onChange(e) {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues()[0];
var lastRow = sheet.getRange(sheet.getLastRow(), 1, 1, sheet.getLastColumn()).getValues()[0];
callRestApi(headers, lastRow);
}
function callRestApi(headers, dataRow) {
var dataObject = {};
for (var i = 0; i < headers.length; i++) {
dataObject[headers[i]] = dataRow[i];
}
var options = {
'method': 'post',
'contentType': 'application/json',
'payload': JSON.stringify({data: dataObject})
};
try {
var response = UrlFetchApp.fetch(url, options);
Logger.log("API 응답: " + response.getContentText());
} catch (error) {
Logger.log("API 호출 중 오류 발생: " + error.toString());
}
}
트리거 설정
앱스 스크립트의 좌측 메뉴에서 트리거를 선택한다.
data:image/s3,"s3://crabby-images/e5cec/e5cec96c3e45512ded65c4f5a9913aae9425a80b" alt=""
다음과 같이 트리거를 추가한다.
data:image/s3,"s3://crabby-images/a610d/a610de00c76f189785472513745406810033b055" alt=""
구글 시트에 데이터 추가
다음과 같이 구글 시트에 데이터를 추가해본다.
data:image/s3,"s3://crabby-images/7cf1c/7cf1cc2b6f0180e82737b18f6480682d504d2fae" alt=""
데이터가 추가되면 다음과 같이 슬랙 채널에 알림이 온다.
data:image/s3,"s3://crabby-images/d854d/d854dbb16b1a5176ab970be5558784858e229e20" alt=""