From 1bb5c6dc0d5b9fa842c7784870a5da475e08bf13 Mon Sep 17 00:00:00 2001 From: limccn Date: Mon, 13 Mar 2023 16:17:54 +0800 Subject: [PATCH] feat: container support voice reply --- docker/build.alpine.sh | 3 +- docker/build.debian.sh | 1 + .../Dockerfile.alpine | 23 ++++ .../Dockerfile.debian | 24 ++++ .../docker-compose.yaml | 24 ++++ .../entrypoint.sh | 117 ++++++++++++++++++ 6 files changed, 191 insertions(+), 1 deletion(-) create mode 100644 docker/chatgpt-on-wechat-voice-reply/Dockerfile.alpine create mode 100644 docker/chatgpt-on-wechat-voice-reply/Dockerfile.debian create mode 100644 docker/chatgpt-on-wechat-voice-reply/docker-compose.yaml create mode 100755 docker/chatgpt-on-wechat-voice-reply/entrypoint.sh diff --git a/docker/build.alpine.sh b/docker/build.alpine.sh index b2022b1..8f102dd 100644 --- a/docker/build.alpine.sh +++ b/docker/build.alpine.sh @@ -11,5 +11,6 @@ docker build -f Dockerfile.alpine \ -t zhayujie/chatgpt-on-wechat . # tag image -docker tag zhayujie/chatgpt-on-wechat zhayujie/chatgpt-on-wechat:$CHATGPT_ON_WECHAT_TAG-alpine +docker tag zhayujie/chatgpt-on-wechat zhayujie/chatgpt-on-wechat:alpine +docker tag zhayujie/chatgpt-on-wechat zhayujie/chatgpt-on-wechat:$CHATGPT_ON_WECHAT_TAG-alpine \ No newline at end of file diff --git a/docker/build.debian.sh b/docker/build.debian.sh index 74b38ac..e7caa15 100644 --- a/docker/build.debian.sh +++ b/docker/build.debian.sh @@ -11,4 +11,5 @@ docker build -f Dockerfile.debian \ -t zhayujie/chatgpt-on-wechat . # tag image +docker tag zhayujie/chatgpt-on-wechat zhayujie/chatgpt-on-wechat:debian docker tag zhayujie/chatgpt-on-wechat zhayujie/chatgpt-on-wechat:$CHATGPT_ON_WECHAT_TAG-debian \ No newline at end of file diff --git a/docker/chatgpt-on-wechat-voice-reply/Dockerfile.alpine b/docker/chatgpt-on-wechat-voice-reply/Dockerfile.alpine new file mode 100644 index 0000000..85248ae --- /dev/null +++ b/docker/chatgpt-on-wechat-voice-reply/Dockerfile.alpine @@ -0,0 +1,23 @@ +FROM zhayujie/chatgpt-on-wechat:alpine + +LABEL maintainer="foo@bar.com" +ARG TZ='Asia/Shanghai' + +USER root + +RUN apk add --no-cache \ + ffmpeg \ + espeak \ + && pip install --no-cache \ + baidu-aip \ + chardet \ + SpeechRecognition + +# replace entrypoint +ADD ./entrypoint.sh /entrypoint.sh + +RUN chmod +x /entrypoint.sh + +USER noroot + +ENTRYPOINT ["/entrypoint.sh"] \ No newline at end of file diff --git a/docker/chatgpt-on-wechat-voice-reply/Dockerfile.debian b/docker/chatgpt-on-wechat-voice-reply/Dockerfile.debian new file mode 100644 index 0000000..4e999e2 --- /dev/null +++ b/docker/chatgpt-on-wechat-voice-reply/Dockerfile.debian @@ -0,0 +1,24 @@ +FROM zhayujie/chatgpt-on-wechat:debian + +LABEL maintainer="foo@bar.com" +ARG TZ='Asia/Shanghai' + +USER root + +RUN apt-get update \ + && apt-get install -y --no-install-recommends \ + ffmpeg \ + espeak \ + && pip install --no-cache \ + baidu-aip \ + chardet \ + SpeechRecognition + +# replace entrypoint +ADD ./entrypoint.sh /entrypoint.sh + +RUN chmod +x /entrypoint.sh + +USER noroot + +ENTRYPOINT ["/entrypoint.sh"] diff --git a/docker/chatgpt-on-wechat-voice-reply/docker-compose.yaml b/docker/chatgpt-on-wechat-voice-reply/docker-compose.yaml new file mode 100644 index 0000000..95ace28 --- /dev/null +++ b/docker/chatgpt-on-wechat-voice-reply/docker-compose.yaml @@ -0,0 +1,24 @@ +version: '2.0' +services: + chatgpt-on-wechat: + build: + context: ./ + dockerfile: Dockerfile.alpine + image: zhayujie/chatgpt-on-wechat-voice-reply + container_name: chatgpt-on-wechat-voice-reply + environment: + OPEN_AI_API_KEY: 'YOUR API KEY' + OPEN_AI_PROXY: '' + SINGLE_CHAT_PREFIX: '["bot", "@bot"]' + SINGLE_CHAT_REPLY_PREFIX: '"[bot] "' + GROUP_CHAT_PREFIX: '["@bot"]' + GROUP_NAME_WHITE_LIST: '["ChatGPT测试群", "ChatGPT测试群2"]' + IMAGE_CREATE_PREFIX: '["画", "看", "找"]' + CONVERSATION_MAX_TOKENS: 1000 + SPEECH_RECOGNITION: 'true' + CHARACTER_DESC: '你是ChatGPT, 一个由OpenAI训练的大型语言模型, 你旨在回答并解决人们的任何问题,并且可以使用多种语言与人交流。' + EXPIRES_IN_SECONDS: 3600 + VOICE_REPLY_VOICE: 'true' + BAIDU_APP_ID: 'YOUR BAIDU APP ID' + BAIDU_API_KEY: 'YOUR BAIDU API KEY' + BAIDU_SECRET_KEY: 'YOUR BAIDU SERVICE KEY' \ No newline at end of file diff --git a/docker/chatgpt-on-wechat-voice-reply/entrypoint.sh b/docker/chatgpt-on-wechat-voice-reply/entrypoint.sh new file mode 100755 index 0000000..81241f3 --- /dev/null +++ b/docker/chatgpt-on-wechat-voice-reply/entrypoint.sh @@ -0,0 +1,117 @@ +#!/bin/bash +set -e + +# build prefix +CHATGPT_ON_WECHAT_PREFIX=${CHATGPT_ON_WECHAT_PREFIX:-""} +# path to config.json +CHATGPT_ON_WECHAT_CONFIG_PATH=${CHATGPT_ON_WECHAT_CONFIG_PATH:-""} +# execution command line +CHATGPT_ON_WECHAT_EXEC=${CHATGPT_ON_WECHAT_EXEC:-""} + +OPEN_AI_API_KEY=${OPEN_AI_API_KEY:-""} +OPEN_AI_PROXY=${OPEN_AI_PROXY:-""} +SINGLE_CHAT_PREFIX=${SINGLE_CHAT_PREFIX:-""} +SINGLE_CHAT_REPLY_PREFIX=${SINGLE_CHAT_REPLY_PREFIX:-""} +GROUP_CHAT_PREFIX=${GROUP_CHAT_PREFIX:-""} +GROUP_NAME_WHITE_LIST=${GROUP_NAME_WHITE_LIST:-""} +IMAGE_CREATE_PREFIX=${IMAGE_CREATE_PREFIX:-""} +CONVERSATION_MAX_TOKENS=${CONVERSATION_MAX_TOKENS:-""} +SPEECH_RECOGNITION=${SPEECH_RECOGNITION:-""} +CHARACTER_DESC=${CHARACTER_DESC:-""} +EXPIRES_IN_SECONDS=${EXPIRES_IN_SECONDS:-""} + +VOICE_REPLY_VOICE=${VOICE_REPLY_VOICE:-""} +BAIDU_APP_ID=${BAIDU_APP_ID:-""} +BAIDU_API_KEY=${BAIDU_API_KEY:-""} +BAIDU_SECRET_KEY=${BAIDU_SECRET_KEY:-""} + +# CHATGPT_ON_WECHAT_PREFIX is empty, use /app +if [ "$CHATGPT_ON_WECHAT_PREFIX" == "" ] ; then + CHATGPT_ON_WECHAT_PREFIX=/app +fi + +# CHATGPT_ON_WECHAT_CONFIG_PATH is empty, use '/app/config.json' +if [ "$CHATGPT_ON_WECHAT_CONFIG_PATH" == "" ] ; then + CHATGPT_ON_WECHAT_CONFIG_PATH=$CHATGPT_ON_WECHAT_PREFIX/config.json +fi + +# CHATGPT_ON_WECHAT_EXEC is empty, use ‘python app.py’ +if [ "$CHATGPT_ON_WECHAT_EXEC" == "" ] ; then + CHATGPT_ON_WECHAT_EXEC="python app.py" +fi + +# modify content in config.json +if [ "$OPEN_AI_API_KEY" != "" ] ; then + sed -i "s/\"open_ai_api_key\".*,$/\"open_ai_api_key\": \"$OPEN_AI_API_KEY\",/" $CHATGPT_ON_WECHAT_CONFIG_PATH +else + echo -e "\033[31m[Warning] You need to set OPEN_AI_API_KEY before running!\033[0m" +fi + +# use http_proxy as default +if [ "$HTTP_PROXY" != "" ] ; then + sed -i "s/\"proxy\".*,$/\"proxy\": \"$HTTP_PROXY\",/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$OPEN_AI_PROXY" != "" ] ; then + sed -i "s/\"proxy\".*,$/\"proxy\": \"$OPEN_AI_PROXY\",/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$SINGLE_CHAT_PREFIX" != "" ] ; then + sed -i "s/\"single_chat_prefix\".*,$/\"single_chat_prefix\": $SINGLE_CHAT_PREFIX,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$SINGLE_CHAT_REPLY_PREFIX" != "" ] ; then + sed -i "s/\"single_chat_reply_prefix\".*,$/\"single_chat_reply_prefix\": $SINGLE_CHAT_REPLY_PREFIX,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$GROUP_CHAT_PREFIX" != "" ] ; then + sed -i "s/\"group_chat_prefix\".*,$/\"group_chat_prefix\": $GROUP_CHAT_PREFIX,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$GROUP_NAME_WHITE_LIST" != "" ] ; then + sed -i "s/\"group_name_white_list\".*,$/\"group_name_white_list\": $GROUP_NAME_WHITE_LIST,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$IMAGE_CREATE_PREFIX" != "" ] ; then + sed -i "s/\"image_create_prefix\".*,$/\"image_create_prefix\": $IMAGE_CREATE_PREFIX,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$CONVERSATION_MAX_TOKENS" != "" ] ; then + sed -i "s/\"conversation_max_tokens\".*,$/\"conversation_max_tokens\": $CONVERSATION_MAX_TOKENS,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$SPEECH_RECOGNITION" != "" ] ; then + sed -i "s/\"speech_recognition\".*,$/\"speech_recognition\": $SPEECH_RECOGNITION,/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$CHARACTER_DESC" != "" ] ; then + sed -i "s/\"character_desc\".*,$/\"character_desc\": \"$CHARACTER_DESC\",/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$EXPIRES_IN_SECONDS" != "" ] ; then + sed -i "s/\"expires_in_seconds\".*$/\"expires_in_seconds\": $EXPIRES_IN_SECONDS/" $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +# append +if [ "$BAIDU_SECRET_KEY" != "" ] ; then + sed -i "1a \ \ \"baidu_secret_key\": \"$BAIDU_SECRET_KEY\"," $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$BAIDU_API_KEY" != "" ] ; then + sed -i "1a \ \ \"baidu_api_key\": \"$BAIDU_API_KEY\"," $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$BAIDU_APP_ID" != "" ] ; then + sed -i "1a \ \ \"baidu_app_id\": \"$BAIDU_APP_ID\"," $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +if [ "$VOICE_REPLY_VOICE" != "" ] ; then + sed -i "1a \ \ \"voice_reply_voice\": $VOICE_REPLY_VOICE," $CHATGPT_ON_WECHAT_CONFIG_PATH +fi + +# go to prefix dir +cd $CHATGPT_ON_WECHAT_PREFIX +# excute +$CHATGPT_ON_WECHAT_EXEC + +