superdup95's picture
Update app.py
45a78d1 verified
raw
history blame
8.17 kB
import gradio as gr
import anthropic
import requests
from api_usage import get_subscription, check_key_availability, check_key_ant_availability, check_key_gemini_availability, check_key_azure_availability, get_azure_status, get_azure_deploy, check_key_mistral_availability, check_mistral_quota, check_key_replicate_availability, check_key_aws_availability
def sort_key(key):
_key = key.strip()
if _key.startswith("sk-ant-"):
return get_key_ant_info(_key)
elif _key.startswith("sk-"):
return get_key_oai_info(_key)
elif _key.startswith("AIzaSy"):
return get_key_gemini_info(_key)
elif (_key.startswith("r8_") and len(_key) == 40) or (_key.islower() and len(_key) == 40):
return get_key_replicate_info(_key)
elif len(_key.split(':')) == 2 and _key.split(':')[1].islower() and len(_key.split(':')[1]) == 32 and "openai.azure.com" not in _key.split(':')[1]:
endpoint = f"{_key.split(':')[0]}.openai.azure.com"
api_key = _key.split(':')[1]
return get_key_azure_info(endpoint, api_key)
elif "openai.azure.com" in _key.split(';')[0]:
endpoint = _key.split(';')[0]
api_key = _key.split(';')[1]
return get_key_azure_info(endpoint, api_key)
elif _key.startswith("AKIA") and len(_key.split(':')[0]) == 20 and _key.split(':')[0].isupper():
return get_key_aws_info(_key)
elif len(_key) == 32:
return get_key_mistral_info(_key)
else:
return not_supported(_key)
def get_key_oai_info(key):
# Return a dictionary containing key information
session = requests.Session()
key_avai = check_key_availability(session, key)
info_dict = {#"account_name": "",
"key_type": "OpenAI",
"key_availability": True if key_avai else False,
"gpt4_availability": "",
"gpt4_32k_availability": "",
"default_org": "",
"org_description": "",
"organization": "",
"models": "",
"requests_per_minute": "",
"tokens_per_minute": "",
#"tokens_per_minute_left": "",
"quota": ""}
if key_avai:
info = get_subscription(key, session, key_avai)
info_dict["gpt4_availability"] = info["has_gpt4"]
info_dict["gpt4_32k_availability"] = info["has_gpt4_32k"]
info_dict["default_org"] = info["default_org"]
info_dict["org_description"] = info["org_description"]
info_dict["organization"] = info["organization"]
info_dict["models"] = info["models"]
info_dict["requests_per_minute"] = info["rpm"]
info_dict["tokens_per_minute"] = info["tpm"]
info_dict["quota"] = info["quota"]
return info_dict
def get_key_ant_info(key):
# Return a dictionary containing key information
ant = anthropic.Anthropic(api_key=key)
key_avai = check_key_ant_availability(ant)
info_dict = {#"account_name": "",
"key_type": "Anthropic Claude",
"key_availability": key_avai[0],
"status": key_avai[1],
"filter_response": key_avai[2]}
return info_dict
def get_key_gemini_info(key):
key_avai = check_key_gemini_availability(key)
info_dict = {#"account_name": "",
"key_type": "Google Gemini",
"key_availability": key_avai[0],
"models": key_avai[1]}
return info_dict
def get_key_gemini_info(key):
key_avai = check_key_gemini_availability(key)
info_dict = {#"account_name": "",
"key_type": "Google Gemini",
"key_availability": key_avai[0],
"models": key_avai[1]}
return info_dict
def get_key_azure_info(endpoint, api_key):
key_avai = check_key_azure_availability(endpoint, api_key)
info_dict = {#"account_name": "",
"key_type": "Microsoft Azure OpenAI",
"key_availability": key_avai[0],
"gpt35_availability": "",
"gpt4_availability": "",
"gpt4_turbo_availability": "",
"gpt4_32k_availability": "",
"moderation_status": "",
"models": "",
"deployments": ""}
if key_avai[0]:
azure_deploy = get_azure_deploy(endpoint, api_key)
status = get_azure_status(endpoint, api_key, azure_deploy)
info_dict["gpt35_availability"] = status[1]
info_dict["gpt4_availability"] = status[2]
info_dict["gpt4_turbo_availability"] = status[3]
info_dict["gpt4_32k_availability"] = status[4]
info_dict["moderation_status"] = status[0]
info_dict["models"] = key_avai[1]
info_dict["deployments"] = azure_deploy
return info_dict
def get_key_mistral_info(key):
key_avai = check_key_mistral_availability(key)
info_dict = {#"account_name": "",
"key_type": "Mistral AI",
"key_availability": True if key_avai else False,
"has_quota": "",
"models": ""}
if key_avai:
info_dict['has_quota'] = check_mistral_quota(key)
info_dict['models'] = key_avai
return info_dict
def get_key_replicate_info(key):
key_avai = check_key_replicate_availability(key)
info_dict = {#"account_name": "",
"key_type": "Replicate",
"key_availability": key_avai[0],
"account_name": "",
"type": "",
"has_quota": "",
"hardware_available": ""}
if key_avai[0]:
info_dict['account_name'] = key_avai[1]['username']
info_dict['type'] = key_avai[1]['type']
info_dict['has_quota'] = key_avai[2]
info_dict['hardware_available'] = key_avai[3]
return info_dict
def get_key_aws_info(key):
key_avai = check_key_aws_availability(key)
info_dict = {#"account_name": "",
"key_type": "Amazon AWS Claude",
"key_availability": key_avai[0],
"username": "",
"root": "",
"admin": "",
"quarantine": "",
"iam_full_access": "",
"claude_v2_enabled_region": key_avai[6],
"claude_sonnet_enabled_region": key_avai[7],
"billing": "",
"cost_and_usage": ""}
if key_avai[0]:
info_dict['username'] = key_avai[1]
info_dict['root'] = key_avai[2]
info_dict['admin'] = key_avai[3]
info_dict['quarantine'] = key_avai[4]
info_dict['iam_full_access'] = key_avai[5]
info_dict['billing'] = key_avai[8]
info_dict['claude_v2_enabled_region'] = key_avai[6]
info_dict['claude_sonnet_enabled_region'] = key_avai[7]
info_dict['cost_and_usage'] = key_avai[9]
return info_dict
def not_supported(key):
info_dict = {#"account_name": "",
"key_type": "Not supported",
"status": ""}
return info_dict
def clear_inputs(text):
return ""
with gr.Blocks() as demo:
gr.Markdown('''
# OpenAI/Anthropic/Gemini/Azure/Mistral/Replicate/AWS Claude API Key Status Checker
*(Based on shaocongma, CncAnon1, Drago and kingbased key checkers)*
AWS credential's format: AWS_ACCESS_KEY_ID:AWS_SECRET_ACCESS_KEY (root might not be accurate)
Azure endpoint's format: YOUR_RESOURCE_NAME:YOUR_API_KEY or (https://)YOUR_RESOURCE_NAME.openai.azure.com;YOUR_API_KEY
''')
with gr.Row():
with gr.Column():
key = gr.Textbox(lines=1, max_lines=1, label="API Key")
with gr.Row():
clear_button = gr.Button("Clear")
submit_button = gr.Button("Submit", variant="primary")
with gr.Column():
info = gr.JSON(label="API Key Information")
clear_button.click(fn=clear_inputs, inputs=[key], outputs=[key])
submit_button.click(fn=sort_key, inputs=[key], outputs=[info], api_name="sort_key")
demo.launch()