ai
[!NOTE|label:references:]
chat tool
[!NOTE|label:references:]
chatgpt
model
[!NOTE|label:references:]
RPM
Requests Per Minute
TPM
Tokens Per Minute
IPM
Images Per Minute
AMPM
Audio Megabytes Per Minute
RPD
Requests Per Day
TPD
Tokens Per Day
-
Batch Tokens Per Day
gpt-3.5-turbo-16k
16,385
-
gpt-4-32k
32,768
-
gpt-4-32k
32,768
-
gpt-4-32k-0613
32,768
-
gpt-3.5-turbo
200,000 TPM
500 RPM 10,000 RPD
2,000,000 TPD
gpt-3.5-turbo-0125
200,000 TPM
500 RPM 10,000 RPD
2,000,000 TPD
gpt-3.5-turbo-1106
200,000 TPM
500 RPM 10,000 RPD
2,000,000 TPD
gpt-3.5-turbo-16k
200,000 TPM
500 RPM 10,000 RPD
2,000,000 TPD
gpt-3.5-turbo-instruct
90,000 TPM
3,500 RPM
200,000 TPD
gpt-3.5-turbo-instruct-0914
90,000 TPM
3,500 RPM
200,000 TPD
gpt-4
10,000 TPM
500 RPM 10,000 RPD
100,000 TPD
gpt-4-0613
10,000 TPM
500 RPM 10,000 RPD
100,000 TPD
gpt-4-turbo ↪︎ gpt-4-turbo-2024-04-09 ↪︎ gpt-4-turbo-preview ↪︎ gpt-4-0125-preview ↪︎ gpt-4-1106-preview
30,000 TPM
500 RPM
90,000 TPD
gpt-4.1 ↪︎ gpt-4.1-2025-04-14
30,000 TPM
500 RPM
900,000 TPD
gpt-4.1 (long context)
200,000 TPM
100 RPM
2,000,000 TPD
gpt-4.1-mini ↪︎ gpt-4.1-mini-2025-04-14
200,000 TPM
500 RPM
2,000,000 TPD
gpt-4.1-mini (long context)
400,000 TPM
200 RPM
4,000,000 TPD
gpt-4.1-nano ↪︎ gpt-4.1-nano-2025-04-14
200,000 TPM
500 RPM
2,000,000 TPD
gpt-4.1-nano (long context)
400,000 TPM
200 RPM
4,000,000 TPD
gpt-4.5-preview ↪︎ gpt-4.5-preview-2025-02-27
125,000 TPM
1,000 RPM
50,000 TPD
gpt-4o ↪︎ gpt-4o-2024-05-13 ↪︎ gpt-4o-2024-08-06 ↪︎ gpt-4o-2024-11-20 ↪︎ gpt-4o-audio-preview ↪︎ gpt-4o-audio-preview-2024-10-01 ↪︎ gpt-4o-audio-preview-2024-12-17
30,000 TPM
500 RPM
90,000 TPD
gpt-4o-mini ↪︎ gpt-4o-mini-2024-07-18 ↪︎ gpt-4o-mini-audio-preview ↪︎ gpt-4o-mini-audio-preview-2024-12-17
200,000 TPM
500 RPM 10,000 RPD
2,000,000 TPD
API
[!NOTE|label:references:]
api type
[!TIP|label:curl commands:]
$ curl -s '${scheme}://${authority}${path}' \ -H 'Authorization: Bearer ${Authorization}' \ -H 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)' \ -H 'Origin: https://platform.openai.com' \ -H 'Referer: https://platform.openai.com/settings/organization/limits' \ -H 'Accept: application/json' \ -H 'Content-Type: application/json'
Public API
/v1/chat/completions
✅ Yes
✅ Stable
✅ Yes
Private API
/dashboard/rate_limits
❌ No
⚠️ May change
⚠️ For personal/internal use only
Internal API
/api/internal/user/settings
❌ No
❌ Unstable
❌ Not recommended
Browser-bound API
Requires session + Origin + Referer headers
❌ No
⚠️ Risky
❌ Manual use only
get authorization key
visit
https://platform.openai.com/settings/organization/limits⌥ + ⌘ + i to open the devtools
open the tab
Network→Fetch/XHR, and search with keywordlimitcheck the item one by one, untile find the one with
Authorization: Bearer sess-****************************************header in theRequest Headersdouble confirm the Response tab has the model limits data

as long as found the correct item, check the Request Headers tab, it will be ( example ):
:authority
api.openai.com
:path
/dashboard/rate_limits
:method
GET
:scheme
https
Authorization
Bearer sess-xxxxxx
[!TIP|label:other APIs]
api.openai.com
/dashboard/billing/subscription
https
GET
api.openai.com
/dashboard/rate_limits
https
GET
api.openai.com
/dashboard/user/api_keys
https
GET
api.openai.com
/dashboard/feature_flags
https
GET
api.openai.com
/v1/dashboard/organizations/<ORGANIZATION_ID>/projects/<PROJECT_ID>/users
https
GET
curl API call example:
$ curl -s '${scheme}://${authority}${path}' \ -H 'Authorization: Bearer ${Authorization}' \ -H 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)' \ -H 'Origin: https://platform.openai.com' \ -H 'Referer: https://platform.openai.com/settings/organization/limits' \ -H 'Accept: application/json' \ -H 'Content-Type: application/json' # i.e.: $ curl -s 'https://api.openai.com/dashboard/rate_limits' \ -H 'Authorization: Bearer sess-xxxxxx' \ -H 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)' \ -H 'Origin: https://platform.openai.com' \ -H 'Referer: https://platform.openai.com/settings/organization/limits' \ -H 'Accept: application/json' \ -H 'Content-Type: application/json'
$ curl -s https://api.openai.com/v1/models \
       -H "Authorization: Bearer $OPENAI_API_KEY"
# or show in table format
$ curl -s https://api.openai.com/v1/models \
       -H "Authorization: Bearer $OPENAI_API_KEY" |
  jq -r '["CREATED AT", "MODEL ID"],
         (.data | sort_by(.created) | reverse[] | [(.created | strftime("%Y-%m-%d %H:%M:%S")), .id])
         | @tsv' |
  column -t -s$'\t'
CREATED AT           MODEL ID
2025-06-02 23:54:58  gpt-4o-audio-preview-2025-06-03
2025-06-02 23:43:58  gpt-4o-realtime-preview-2025-06-03
2025-05-08 03:00:57  codex-mini-latest
2025-04-24 17:50:30  gpt-image-1
...model_limits
$ curl -s https://api.openai.com/v1/fine_tuning/model_limits \
       -H "Authorization: Bearer ${OPENAI_API_KEY}"
# with table format
$ curl -s https://api.openai.com/v1/fine_tuning/model_limits \
       -H "Authorization: Bearer $OPENAI_API_KEY" |
  jq -r '["ID", "PENDING JOBS", "MAX PENDING JOBS", "JOBS", "MAX JOBS/DAY"],
         (.data[] | [.id, .curr_pending_jobs, .max_pending_jobs, .jobs_so_far_today, .max_jobs_per_day])
         | @tsv' |
  column -t -s$'\t'
ID                       PENDING JOBS  MAX PENDING JOBS  JOBS  MAX JOBS/DAY
gpt-3.5-turbo-0125       0             3                 0     48
gpt-3.5-turbo-1106       0             3                 0     48
gpt-4.1-2025-04-14       0             3                 0     8
gpt-4.1-mini-2025-04-14  0             6                 0     24
gpt-4.1-nano-2025-04-14  0             6                 0     24
gpt-4o-2024-08-06        0             3                 0     8
gpt-4o-mini-2024-07-18   0             5                 0     24
o4-mini-2025-04-16       0             2                 0     4
# or
$ (
    echo "model | curr pending | max pending | today jobs | max daily jobs" | tr '[:lower:]' '[:upper:]';
    curl -s https://api.openai.com/v1/fine_tuning/model_limits -H "Authorization: Bearer ${OPENAI_API_KEY}" |
      jq -r '.data[] | [.id, .curr_pending_jobs, .max_pending_jobs, .jobs_so_far_today, .max_jobs_per_day] | @tsv' |
      while IFS=$'\t' read -r model curr max today maxday; do
        echo "${model} | ${curr} | ${max} | ${today} | ${maxday}";
      done
  ) | column -t -s '|'rate_limits
[!TIP|label:references:]
$ curl -s https://api.openai.com/dashboard/rate_limits \
       -H 'Authorization: Bearer sess-s**************************************P' \
       -H 'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)' \
       -H 'Accept: application/json' \
       -H 'Content-Type: application/json' |
  jq -r 'to_entries |
         (["MODEL", "RPM", "TPM", "IMAGES/MIN", "AUDIO_MB/MIN", "RPD", "BATCH_TOKENS"]),
         (.[] | [
           .key,
           (.value.max_requests_per_1_minute        // "-" | if . == "-" then . else (. | tostring + " RPM") end),
           (.value.max_tokens_per_1_minute          // "-" | if . == "-" then . else (. | tostring + " TPM") end),
           (.value.max_images_per_1_minute          // "-" | if . == "-" then . else (. | tostring + " IPM") end),
           (.value.max_audio_megabytes_per_1_minute // "-" | if . == "-" then . else (. | tostring + " MB/min") end),
           (.value.max_requests_per_1_day           // "-" | if . == "-" then . else (. | tostring + " req/day") end),
           (.value.batch_1_day_max_input_tokens     // "-" | if . == "-" then . else (. | tostring + " tokens") end)
         ]) | @tsv' |
  column -t -s $'\t'admin key
[!TIP|label:OPENAI_ADMIN_KEY:]
# get user id, can be used for `-H "OpenAI-User: user-xxxxxxxxxxxxxxxx"`
$ curl -s https://api.openai.com/v1/organization/users \
       -H "Authorization: Bearer $OPENAI_ADMIN_KEY" \
       -H "Content-Type: application/json"
# get details of admin key
$ curl -s https://api.openai.com/v1/organization/admin_api_keys \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json"organization id
# get organization id, can be used for `-H "OpenAI-Organization: org-xxxxxxxxxxxxxxxx"`
$ curl -s https://api.openai.com/v1/organizations \
       -H "Authorization: Bearer sess-s**************************************P" \
       -H "Content-Type: application/json" |
  jq -r '.data[].id'
org-G**********************o
# or with ADMIN_KEY
$ curl -s https://api.openai.com/v1/organizations \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json" |
  jq -r '.data[].id'
org-GUjEKO81ydwmSGORg4boXRsogroup id
[!TIP|label:group id:]
to get group id, can be used for
-H "OpenAI-Group: group-xxxxxxxxxxxxxxxx"
# or show in table format
$ curl -s https://api.openai.com/v1/organization/projects \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json" |
  jq -r '["NAME", "GROUP ID"], (.data[] | [.name, .id]) | @tsv' |
  column -t -s$'\t'
NAME             GROUP ID
Default project  proj_f**********************4
marslo           proj_E**********************m
# or via organization API
$ curl -s https://api.openai.com/v1/organizations \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json" |
  jq -r '["NAME", "GROUP ID"], (.data[].projects.data[] | [.title, .id]) | @tsv' |
  column -t -s$'\t'
NAME             GROUP ID
Default project  proj_f**********************4
marslo           proj_E**********************m
$ curl -s https://api.openai.com/v1/organization/projects \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json" |
  jq -r '.data[] | select(.name == "marslo") | .id'
# or show name and id
$ curl -s https://api.openai.com/v1/organization/projects \
       -H "Authorization: Bearer ${OPENAI_ADMIN_KEY}" \
       -H "Content-Type: application/json" |
  jq -r '.data[] | "\(.name)|\(.id)"' | column -t -s'|'
using chatgpt to generate git commits
#!/usr/bin/env bash
set -euo pipefail
model="${COMMITX_MODEL:-gpt-4-1106-preview}"
temperature="${COMMITX_TEMPERATURE:-0.3}"
OPENAI_API_KEY="${OPENAI_API_KEY:? OPENAI_API_KEY not set}"
diff=$(git --no-pager diff --color=never)
prompt="Generate a Git commit message in the Conventional Commits format, with the following structure:
<type>(<scope1,scope2,...>): short summary
- detail 1
- detail 2
- ...
Use multiple scopes if the diff includes changes in multiple areas.
Use markdown-style bullet points for details.
Do not include explanations or code.
Base it on the following diff:
$diff"
declare payload
payload=$(jq -n \
  --arg model "$model" \
  --arg temp "$temperature" \
  --arg prompt "$prompt" \
  '{
    model: $model,
    temperature: ($temp | tonumber),
    messages: [
      { role: "system", content: "You are an assistant that writes Git commit messages." },
      { role: "user", content: $prompt }
    ]
  }')
curl -s https://api.openai.com/v1/chat/completions \
  -H "Authorization: Bearer $OPENAI_API_KEY" \
  -H "Content-Type: application/json" \
  -d "$payload" |
jq -r '.choices[0].message.content'
# vim:tabstop=2:softtabstop=2:shiftwidth=2:expandtab:filetype=shusing chatgpt to review git diff
#!/usr/bin/env bash
set -euo pipefail
MODEL="${COMMITX_MODEL:-gpt-4-turbo}"
TEMPERATURE="${COMMITX_TEMPERATURE:-0.3}"
OPENAI_API_KEY="${OPENAI_API_KEY:? OPENAI_API_KEY not set}"
diff=$(git --no-pager diff --color=never)
prompt="You are a Principal Software Architect reviewing a Git diff.
You may not have the full code context, but please still provide a professional code review.
Focus on:
- What the changes are doing
- Code quality, style, naming, structure
- Potential bugs or anti-patterns
- Suggestions for improvement
Use markdown. Be helpful, concise, and insightful.
--- START DIFF ---
${diff}
--- END DIFF ---"
curl -s https://api.openai.com/v1/chat/completions \
  -H "Authorization: Bearer $OPENAI_API_KEY" \
  -H "Content-Type: application/json" \
  -d "$(jq -n \
    --arg model "$MODEL" \
    --arg temp "$TEMPERATURE" \
    --arg prompt "$prompt" \
    ' {
      model: $model,
      temperature: ($temp | tonumber),
      messages: [
        { role: "system", content: "You are a senior engineer performing code review." },
        { role: "user", content: $prompt }
      ]
    }')" |
jq -r '.choices[0].message.content'
# vim:tabstop=2:softtabstop=2:shiftwidth=2:expandtab:filetype=shRAG
[!TIP]
tips
chatgpt
import os
from pathlib import Path
# Define script contents
table_script = """#!/usr/bin/env bash
# print_table.sh — CLI 表格打印工具,支持列对齐和彩色输出
_strip_ansi() {
  sed 's/\\x1B\\[[0-9;]*[mK]//g'
}
_str_length() {
  echo -e "$1" | _strip_ansi | awk '{ print length }'
}
repeat_char() {
  printf "%*s" "$2" '' | tr ' ' "$1"
}
print_table() {
  local -n _headers=$1
  local -n _rows=$2
  local -n _aligns=$3
  local cols=${#_headers[@]}
  local -a widths
  # 计算每列最大宽度
  for ((i = 0; i < cols; i++)); do
    widths[i]=$(_str_length "${_headers[i]}")
  done
  for row in "${_rows[@]}"; do
    IFS='|' read -r -a fields <<<"$row"
    for ((i = 0; i < cols; i++)); do
      len=$(_str_length "${fields[i]}")
      ((len > widths[i])) && widths[i]=$len
    done
  done
  # 打印分割线
  _print_line() {
    for ((i = 0; i < cols; i++)); do
      printf "+-%s" "$(repeat_char '-' "${widths[i]}")"
    done
    echo "+"
  }
  # 打印一行
  _print_row() {
    local -a fields=("$@")
    for ((i = 0; i < cols; i++)); do
      local raw="${fields[i]}"
      local clean=$(_str_length "$raw")
      local pad=${widths[i]}
      case "${_aligns[i]}" in
        right)
          printf "| %*s " "$pad" "$raw"
          ;;
        center)
          local left=$(( (pad - clean) / 2 ))
          local right=$(( pad - clean - left ))
          printf "| %*s%s%*s " "$left" "" "$raw" "$right" ""
          ;;
        *)
          printf "| %-*s " "$pad" "$raw"
          ;;
      esac
    done
    echo "|"
  }
  # 打印整张表格
  _print_line
  _print_row "${_headers[@]}"
  _print_line
  for row in "${_rows[@]}"; do
    IFS='|' read -r -a fields <<<"$row"
    _print_row "${fields[@]}"
  done
  _print_line
}
"""
# Define output path
output_path = Path("/mnt/data/cli-ui/print_table.sh")
output_path.parent.mkdir(parents=True, exist_ok=True)
# Save script to file
with open(output_path, "w") as f:
    f.write(table_script)
output_path.nameLast updated
Was this helpful?