Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/LemonDouble/chatgpt-serverless-discord-bot

ChatGPT API와 AWS Lambda를 이용하여 Serverless Discord Bot을 만들 수 있는 템플릿입니다.
https://github.com/LemonDouble/chatgpt-serverless-discord-bot

chatgpt discord-bot discord-interactions openai serverless

Last synced: 11 days ago
JSON representation

ChatGPT API와 AWS Lambda를 이용하여 Serverless Discord Bot을 만들 수 있는 템플릿입니다.

Awesome Lists containing this project

README

        

# chatgpt-serverless-discord-bot





서버 유지 비용 없는 커스텀 ChatGPT Discord Bot 템플릿




### AWS Lambda와 OpenAI API를 이용한 Serverless ChatGPT 봇 생성 템플릿입니다.

- **서버 유지관리 비용 (거의)없음** : Serverless 아키텍쳐를 이용해 AWS Lambda에 봇을 호스팅합니다. 한 달 동안 100만건의 요청이 무료입니다!
- **간단한 프롬프트 수정** : 프롬프트를 간단히 수정하여 ChatGPT를 커스터마이징 할 수 있습니다. 친구를 따라하는 봇을 만들어보세요!
- **고가용성** : 서버가 다운되거나 하는 걸 걱정할 필요가 없습니다!
- **배포 및 수정** : 한번 설정해 두었다면, `serverless deploy` 명령 한 번으로 코드를 수정하고 변경할 수 있습니다!

### 설정 방법

**0. 이 리포지토리를 Fork 또는 Clone하고, .env.example 파일을 .env로 이름을 바꿔 주세요.**

**1. Discord 봇 생성**

- https://discordapp.com/developers/applications/ 에 접속하여 New Application을 눌러 새로운 Application을 생성합니다.
- Application 생성 후, 좌측의 `Bot` 탭에서 새로운 봇을 생성해 주세요.
- 그리고 `TOKEN`의 COPY 버튼을 누른 후, .env 파일의 `DISCORD_TOKEN` 부분에 붙여넣어 주세요.
- 이후 General Information 탭에서
- `APPLICATION ID` 를 .env 파일의 `DISCORD_APPLICATION_ID` 부분에 붙여넣어 주세요.
- `PUBLIC KEY` 를 .env 파일의 `DISCORD_PUBLIC_KEY` 부분에 붙여넣어 주세요.

**2. OpenAI API Token 발급**

- https://platform.openai.com/ 에 접속하여 가입 후, `Settings > Manage Account > Billing` 에서 카드를 등록해 주세요.
- 이후 `API Keys > +Create New secret key` 를 눌러 API 키를 생성 후, .env 파일의 `OPENAI_API_KEY` 부분에 붙여넣어 주세요.

**3. Node.js 설치 및 Serverless Framework 설정**

- https://nodejs.org/en/download/ 에 들어가서 Node.js를 다운 후 설치해 주세요.
- 이후 커맨드라인에서 `npm install -g serverless` 를 입력하여 Serverless Framework를 설치해 주세요. ([관련 문서](https://www.serverless.com/framework/docs/getting-started))

**4. AWS 접속 권한 설정**

- AWS에 가입하지 않았다면, AWS에 가입해 주세요. https://console.aws.amazon.com/console/home
- 콘솔에 로그인 후, `IAM -> 사용자 -> 사용자 추가` 를 눌러 새 사용자를 등록해 주세요.
- 사용자 이름에 적절한 이름을 적어 주세요. 저는 `serverless-framework-deploy` 로 설정했습니다.
- 이후 권한 설정에서 `직접 정책 연결 -> AdministratorAccess` 를 추가한 후, 다음 버튼을 눌러주세요.
- 이후 사용자 생성 버튼을 누르면 새로운 사용자가 생성됩니다.
- 이후, `사용자` 방금 탭에서 방금 생성한 유저를 클릭합니다.
- 이후 `보안 자격 증명` 탭에서 `액세스 키 만들기` 를 클릭합니다.
- `Command Line Interface(CLI)` 를 선택한 후, `위의 권장 사항을 이해했으며 액세스 키 생성을 계속하려고 합니다.` 를 체크 후 `다음`을 클릭합니다.
- 설명 태그 값에 적당한 이름을 적습니다. 저는 `access key for serverless deploy` 라고 적었습니다.
- ⚠️이후 생성된 키로 Serverless Framework를 설정합니다. 이 때, Key가 유출되지 않도록 조심해 주세요!! 이 키가 유출되면, 누구나 내 AWS 계정을 사용할 수 있습니다!!⚠️
- 파일에 저장해 두지 말고, 한번 설정한 이후 창을 닫아버리는 것을 추천합니다.
- 다시 커맨드라인으로 돌아가서, `serverless config credentials --provider aws --key <액세스 키> --secret <비밀 액세스 키>` 를 설정합니다.
- 이런 모양입니다 : `serverless config credentials --provider aws --key AKIAIOSFODNN7EXAMPLE --secret wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY`

**5. 서버 배포**

- 커맨드라인에서 다음 커맨드를 실행하여, 관련 플러그인을 설치합니다.
- `serverless plugin install -n serverless-plugin-typescript`
- `serverless plugin install -n serverless-dotenv-plugin`
- 이후 서버를 배포합니다! `serverless deploy` 커맨드를 입력해 주세요.
- 이후 서버가 AWS에 올라가고, 잠깐 기다리면 `Endpoint : ANY - https://jkjadf823.execute-api.ap-northeast-1.amazonaws.com/` 와 같은 글이 뜹니다.
- 이 URL을 복사해 주세요.

**6. 디스코드 봇에 내 서버 등록 및 봇 초대**

- https://discord.com/developers/applications 에 다시 접속해, 1. 에서 생성한 어플리케이션을 찾습니다.
- `General Information > INTERACTIONS ENDPOINT URL` 에 방금 복사한 URL을 입력하고 저장해 주세요. 이 과정을 통해 내 디스코드 봇과, 서버가 연결됩니다.
- 이후 초대 링크를 생성합니다. `OAuth2 -> URL Generator` 에 접속합니다.
![image](https://user-images.githubusercontent.com/31124212/222872546-9353dc83-6319-4b55-9498-a7e7e6b0db23.png)
- 위와 같이 권한을 설정하고, URL을 저장합니다. 이 URL이 내 봇 초대 링크입니다!
- 이후, 해당 URL로 접속하여 내 서버에 봇을 초대합니다.

**7. 슬래시 커맨드 등록**

- 슬래시 커맨드란, 다음과 같은 것을 말합니다.



- 디스코드 서버에 별도로 Slash Command를 등록해야, 채팅창에 `/`를 입력했을 때 위와 같은 커맨드가 등록되게 됩니다.
- 리포지토리에서 `npm install --global yarn` 커맨드를 입력해 yarn을 설치해 주세요.
- 이후 `yarn install`을 입력하여 관련 라이브러리를 설치해 주세요.
- 이후, `.env` 파일을 수정하여 주세요. 위 사진에서 `질문` 은 Command에, `내용` 은 Options에 대응됩니다.
- 이후 `yarn deploy`를 입력하여, 커맨드를 등록해 주세요.

**8. 완료**
- 봇을 초대하고, 위에서 등록한 `/Command` 를 이용해 봇과 대화해 보세요!

### FAQ

- **프롬프트를 수정하고 싶어요!**
- src/openai-response/openai.ts 에 들어가서, `generatePrompt` 내부의 글자를 수정합니다. 이 때, Question은 유저가 입력한 값입니다.
- 기본값으론, 예를 들어 유저가 "안녕" 이라고 입력했다면 ChatGPT에게는 다음과 같이 전달됩니다.
```
너는 디스코드에서 운영되고 있는 봇이야.
너는 가능한 한 친절하게 대답해야 해.
이 질문에 대해 답해봐.
질문 : 안녕
```
- 수정을 완료했다면, `serverless deploy`를 입력하여 서버를 업데이트합니다.
- **슬래시 커맨드를 수정하고 싶어요!**
- .env.example에서 `COMMAND_NAME`, `COMMAND_DESCRIPTION`, `OPTION_NAME`, `OPTION_DESCRIPTION` 을 수정합니다.
- 이후 `yarn deploy`를 입력하여, 수정된 Slash Command를 등록하고 서버를 업데이트합니다.
- 더 자세한 커스터마이징을 원하면, 관련 문서를 참고해 직접 커스터마이징 해 주세요. `src/commands.ts`, `src/proxy/handler.ts`를 수정하면 됩니다.
- 관련 문서 (Discord Interactions) : https://discord.com/developers/docs/interactions/receiving-and-responding
- **봇을 여러 개 만들고 싶어요!**
- 이 리포지토리를 클론한 후, serverless.yml 파일에서 `provider.stage` 부분을 변경하면 Lambda 함수 이름 충돌이 나지 않습니다.
- Stage만 변경해서 여러 봇을 배포해 보세요!

### 프로젝트 구조

```
.
├── README.md # 지금 읽고 있는 이 파일입니다.
├── handler.ts # AWS Lambda가 Discord 서버로부터 요청을 받으면 실행되는 파일입니다. 내부의 handle 함수가 실행됩니다.
├── package.json
├── register.ts # Discord Server에 Slash Command를 등록할 떄 실행되는 파일입니다.
├── serverless.yml
├── src
│ ├── openai-response
│ │ ├── handler.ts # proxy/handler.ts 에 의해 호출되는 함수입니다. OpenAI 서버와 통신 후 Discord 대화를 업데이트합니다.
│ │ └── openai.ts # OpenAI API를 사용하기 위한 파일입니다. generatePrompt 함수를 수정하여 프롬프트를 변경할 수 있습니다.
│ ├── proxy
│ │ └── handler.ts # 요청을 받으면 openai-response/handler를 비동기적으로 호출 뒤, 바로 응답을 반환합니다.
│ ├── commands.ts # 등록되는 Slash Command입니다.
│ └── util.ts # 유틸 함수입니다.
├── tsconfig.json
└── yarn.lock
```

![image](https://user-images.githubusercontent.com/31124212/222947308-df2a3b89-e9f2-490b-af39-2b6276d2a085.png)

### 업데이트 노트

* v0.0.1 : 기본 API 및 응답 구현
* v0.1.1 : 3초 이상 걸리는 Response도 정상 응답 가능하도록, Multi Layer Architecture로 변경
* v0.1.2 : Slash Command 커스터마이즈 지원
* v0.1.3 : Stage를 환경 변수로 주입하여 여러 봇 배포하기 편하도록 수정