これは、シンプルな Raycast AI API プロキシです。サブスクリプションなしで Raycast AIを使用できる代替手段です。このプロキシは、RaycastのリクエストをOpenAIのAPIに変換し、応答をリアルタイムで変換してRaycastに転送します。
本プロジェクトはミドルマンプロキシの方式を採用し、RaycastのリクエストをOpenAIのAPIに転送し、OpenAIの応答をRaycastに転送します。
本プロジェクトは以下のインターフェイスを主にマッピングしています:
GET /api/v1/me
: ユーザーのAI機能のフラグを変更POST /api/v1/translations
: 翻訳インターフェイスPOST /api/v1/ai/chat_completions
: AI機能の共通インターフェイスGET /api/v1/ai/models
: AIモデルのリストインターフェイス
ミドルマンプロキシの簡単な原理は、DNSを変更してRaycastのリクエストのIPを本プロジェクトのアドレスに向け、その後リクエストをOpenAIのAPIに転送し、そこで得た応答をRaycastに転送することです。 しかし、RaycastとRaycast APIの間ではHTTPSが使用されているため、自署証明書が必要であり、Raycastがその証明書を信頼する必要があります。詳細なミドルマンプロキシの原理については(https://docs.mitmproxy.org/stable/conc epts-howmitmproxyworks/)をご参照ください。
複数のモデルを同時に使用することが可能で、ただし環境変数を設定する必要があります
モデルプロバイダー | モデル | テスト状況 | 環境変数 |
---|---|---|---|
openai |
gpt-3.5-turbo,gpt-4-turbo, gpt-4o | テスト済み | OPENAI_API_KEY |
azure openai |
同上 | テスト済み | AZURE_OPENAI_API_KEY , AZURE_DEPLOYMENT_ID , OPENAI_AZURE_ENDPOINT |
google |
gemini-pro,gemini-1.5-pro | テスト済み | GOOGLE_API_KEY |
anthropic |
claude-3-sonnet, claude-3-opus, claude-3-5-opus | テスト済み | ANTHROPIC_API_KEY |
!(./assert/img/chat.jpeg)
!(./assert/img/translate.jpg)
pip3 install mitmproxy
python -c "$(curl -fsSL https://raw.githubusercontent.com/yufeikang/raycast_api_proxy/main/scripts/cert_gen.py)" --domain backend.raycast.com --out ./cert
あるいは
このリポジトリをクローンし、以下のコマンドを実行
pdm run cert_gen
cert
フォルダ内のCA証明書を開き、システムキーチェーンに追加して信頼する必要があります。
これは必須です。Raycast AI プロキシは自署証明書を使用しているため、それを信頼しなければ正常に動作しません。
注意:
Apple
Silicon搭載のmacOSを使用している場合、手動で鍵のアクセス
にCA証明書を追加する際にアプリケーションがハングする問題が発生した場合には、以下のコマンドをターミナルで使用して代替することがで
きます:
sudo security add-trusted-cert -d -p ssl -p basic -k /Library/Keychains/System.keychain ~/.mitmproxy/mitmproxy-ca-cert.pem
127.0.0.1 backend.raycast.com
::1 backend.raycast.com
この変更の目的は、backend.raycast.com
をローカルアドレス(127.0.0.1)に向けることで、実際のbackend.raycast.com
ではなくプロキシにリクエストを送信することです。
当然ながら、独自のDNSサーバーにこのレコードを追加することも可能です。最終的な目的は、backend.raycast.com
をプロキシのデプロイアドレスに向けることです。ここでの127.0.0.1は、デプロイアド
レスに置き換えることができます。このプロジェクトをクラウドやローカルネットワークにデプロイした場合、そのデプロイアドレスに向けるように設定できます。
docker run --name raycast \
-e OPENAI_API_KEY=$OPENAI_API_KEY \
-p 443:443 \
--dns 1.1.1.1 \
-v $PWD/cert/:/data/cert \
-e CERT_FILE=/data/cert/backend.raycast.com.cert.pem \
-e CERT_KEY=/data/cert/backend.raycast.com.key.pem \
-e LOG_LEVEL=INFO \
-d \
ghcr.io/yufeikang/raycast_api_proxy:main
このサービスをクラウドまたはローカルネットワークにデプロイし、Raycastがそのアドレスにアクセスできるようにすることも可能です。
その後、Raycastを再起動して使用を開始できます。
How to switch between OpenAI and Azure OpenAI endpoints with Pythonを参考にしてください。
適切な環境変数を設定するだけでOKです。
docker run --name raycast \
-e OPENAI_API_KEY=$OPENAI_API_KEY \
-e OPENAI_BASE_URL=https://your-resource.openai.azure.com \
-e OPENAI_API_VERSION=2023-05-15 \
-e OPENAI_API_TYPE=azure \
-e AZURE_DEPLOYMENT_ID=your-deployment-id \
-p 443:443 \
--dns 1.1.1.1 \
-v $PWD/cert/:/data/cert \
-e CERT_FILE=/data/cert/backend.raycast.com.cert.pem \
-e CERT_KEY=/data/cert/backend.raycast.com.key.pem \
-e LOG_LEVEL=INFO \
-d \
ghcr.io/yufeikang/raycast_api_proxy:main
OpenAI APIと併せて同時に使用することが可能です。必要に応じて環境変数を設定するだけです。
Google API Keyを取得し、それをGOOGLE_API_KEY
として環境変数にエクスポートします。
# このリポジトリをクローンしてディレクトリに移動
docker build -t raycast .
docker run --name raycast \
-e GOOGLE_API_KEY=$GOOGLE_API_KEY \
-p 443:443 \
--dns 1.1.1.1 \
-v $PWD/cert/:/data/cert \
-e CERT_FILE=/data/cert/backend.raycast.com.cert.pem \
-e CERT_KEY=/data/cert/backend.raycast.com.key.pem \
-e LOG_LEVEL=INFO \
-d \
raycast:latest
- このリポジトリをクローンします
pdm install
を使用して依存関係をインストール- 環境変数を作成
export OPENAI_API_KEY=<your openai api key>
./scripts/cert_gen.py --domain backend.raycast.com --out ./cert
を使用して自署証明書を生成python ./app/main.py
でサービスを起動
ローカル開発中にDNSがループしてしまうのを避けるために、Dockerを使用し、指定したDNSで開発環境を起動することが推奨されます。
参考:
sh ./local_docker.sh
プロジェクトディレクトリ内のcustom_mapping.yml.example
ファイルを参考にして、いくつかのインターフェイスの応答をカスタムマッピングで変更することができます。
"api/v1/me/trial_status":
get:
response:
body:
# jsonパスの置換
"$.trial_limits.commands_limit": 30
例えば上記の設定では、GET api/v1/me/trial_status
インターフェイスの応答の中で $.trial_limits.commands_limit
を 30
に置き換えます。それぞれの$.trial_limits.commands_limit
は
(https://goessner.net/articles/JsonPath/) です。
現在のところ、レスポンスボディの置換のみサポートされています。
複数のユーザーがこのサービスを共有する場合や、サービスをパブリックにデプロイする場合、サービスを使用できるユーザーを制限することができます。 ALLOWED_USERS
環境変数を設定して、このサービスを使用できるユーザーを制限します。
ALLOWED_USERS="[email protected],[email protected]"
メールアドレスはRaycastユーザーのメールアドレスであり、複数のユーザーはカンマで区切ります。
-
DNS指定 GFWの存在により、中国国内で使用する場合、国内のDNSサーバーを指定する必要がある場合があります。例:
--dns 223.5.5.5
-
DNSの無効化 macOSで
/etc/hosts
ファイルを変更してもDNSが有効にならない場合があり、現時点での解決方法は見つかっていません。Raycastを再起動するか、/etc/hosts
ファイルを再編集する方法が有効になること があります。