ChatGPT Backend API Hook

Hook ChatGPT backend API and add missing features

  1. // ==UserScript==
  2. // @name ChatGPT Backend API Hook
  3. // @namespace http://tampermonkey.net/
  4. // @version 0.5
  5. // @description Hook ChatGPT backend API and add missing features
  6. // @match https://chatgpt.com/*
  7. // @grant none
  8. // ==/UserScript==
  9.  
  10. (function() {
  11. 'use strict';
  12.  
  13.  
  14. const mockResponse = `{
  15. "models": [
  16. {
  17. "slug": "text-davinci-002-render-sha",
  18. "max_tokens": 8191,
  19. "title": "Default (GPT-3.5)",
  20. "description": "我们最快的模型,非常适合大多数日常任务。",
  21. "tags": [
  22. "gpt3.5"
  23. ],
  24. "capabilities": {},
  25. "product_features": {}
  26. },
  27. {
  28. "slug": "gpt-4o",
  29. "max_tokens": 8192,
  30. "title": "Scallion",
  31. "description": "浏览、高级数据分析和 DALL·E 现已集成到 GPT-4 中",
  32. "tags": [
  33. "confidential",
  34. "gpt4"
  35. ],
  36. "capabilities": {},
  37. "product_features": {
  38. "attachments": {
  39. "type": "retrieval",
  40. "accepted_mime_types": [
  41. "text/x-java",
  42. "application/x-latext",
  43. "text/javascript",
  44. "text/x-script.python",
  45. "application/pdf",
  46. "text/html",
  47. "text/x-php",
  48. "text/x-c",
  49. "text/x-csharp",
  50. "application/vnd.openxmlformats-officedocument.presentationml.presentation",
  51. "text/x-tex",
  52. "application/json",
  53. "text/plain",
  54. "application/msword",
  55. "text/x-ruby",
  56. "text/markdown",
  57. "text/x-sh",
  58. "text/x-typescript",
  59. "text/x-c++",
  60. "application/vnd.openxmlformats-officedocument.wordprocessingml.document"
  61. ],
  62. "image_mime_types": [
  63. "image/jpeg",
  64. "image/gif",
  65. "image/webp",
  66. "image/png"
  67. ],
  68. "can_accept_all_mime_types": true
  69. }
  70. },
  71. "enabled_tools": [
  72. "tools",
  73. "tools2"
  74. ]
  75. },
  76. {
  77. "slug": "auto",
  78. "max_tokens": 8192,
  79. "title": "Dynamic",
  80. "description": "使用合适的模型来满足我的请求",
  81. "tags": [
  82. "confidential",
  83. "gpt4"
  84. ],
  85. "capabilities": {},
  86. "product_features": {
  87. "attachments": {
  88. "type": "retrieval",
  89. "accepted_mime_types": [
  90. "text/x-java",
  91. "application/x-latext",
  92. "text/javascript",
  93. "text/x-script.python",
  94. "application/pdf",
  95. "text/html",
  96. "text/x-php",
  97. "text/x-c",
  98. "text/x-csharp",
  99. "application/vnd.openxmlformats-officedocument.presentationml.presentation",
  100. "text/x-tex",
  101. "application/json",
  102. "text/plain",
  103. "application/msword",
  104. "text/x-ruby",
  105. "text/markdown",
  106. "text/x-sh",
  107. "text/x-typescript",
  108. "text/x-c++",
  109. "application/vnd.openxmlformats-officedocument.wordprocessingml.document"
  110. ],
  111. "image_mime_types": [
  112. "image/jpeg",
  113. "image/gif",
  114. "image/webp",
  115. "image/png"
  116. ],
  117. "can_accept_all_mime_types": true
  118. }
  119. },
  120. "enabled_tools": [
  121. "tools",
  122. "tools2"
  123. ]
  124. }
  125. ],
  126. "categories": [
  127. {
  128. "category": "gpt_3.5",
  129. "human_category_name": "GPT-3.5",
  130. "human_category_short_name": "3.5",
  131. "icon": "bolt",
  132. "icon_src": "",
  133. "subscription_level": "free",
  134. "default_model": "text-davinci-002-render-sha",
  135. "code_interpreter_model": "text-davinci-002-render-sha-code-interpreter",
  136. "plugins_model": "text-davinci-002-render-sha-plugins",
  137. "color": "#47C761",
  138. "short_explainer": "非常适合用于日常任务",
  139. "tagline": "最快速"
  140. },
  141. {
  142. "category": "AG8PqS2q",
  143. "human_category_name": "GPT-4o",
  144. "human_category_short_name": "4o",
  145. "icon": "stars",
  146. "icon_src": "",
  147. "subscription_level": "plus",
  148. "default_model": "gpt-4o",
  149. "color": "#5B41F9",
  150. "short_explainer": "Newest and most advanced model",
  151. "tagline": "智能且快速"
  152. },
  153. {
  154. "category": "auto",
  155. "human_category_name": "Dynamic",
  156. "human_category_short_name": "",
  157. "icon": "connected",
  158. "icon_src": "",
  159. "subscription_level": "free",
  160. "default_model": "auto",
  161. "plugins_model": "gpt-4-plugins",
  162. "color": "",
  163. "short_explainer": "为改善速度和智能程度而进行了优化。",
  164. "tagline": ""
  165. }
  166. ]
  167. }`;
  168.  
  169. const originalFetch = window.fetch;
  170.  
  171. window.fetch = async function(url, options) {
  172. if (typeof url === 'string' && url.includes('/backend-api/models')) {
  173. return new Promise(resolve => {
  174. resolve(new Response(mockResponse, {
  175. status: 200,
  176. headers: { 'Content-Type': 'application/json' }
  177. }));
  178. });
  179. } else {
  180. return originalFetch(url, options);
  181. }
  182. };
  183. })();