File size: 17,364 Bytes
cd872f9
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
<h1>cursor-api</h1>

<h2>说明</h2>

<ul>
  <li>当前版本已稳定,若发现响应出现缺字漏字,与本程序无关。</li>
  <li>若发现首字慢,与本程序无关。</li>
  <li>若发现响应出现乱码,也与本程序无关。</li>
  <li>属于官方的问题,请不要像作者反馈。</li>
  <li>本程序拥有堪比客户端原本的速度,甚至可能更快。</li>
  <li>本程序的性能是非常厉害的。</li>
  <li>根据本项目开源协议,Fork的项目不能以作者的名义进行任何形式的宣传、推广或声明。</li>
</ul>

<h2>获取key</h2>

<ol>
  <li>访问 <a href="https://www.cursor.com">www.cursor.com</a> 并完成注册登录</li>
  <li>在浏览器中打开开发者工具(F12)</li>
  <li>在 Application-Cookies 中查找名为 <code>WorkosCursorSessionToken</code> 的条目,并复制其第三个字段。请注意,%3A%3A 是 :: 的 URL 编码形式,cookie
    的值使用冒号 (:) 进行分隔。</li>
</ol>

<h2>配置说明</h2>

<h3>环境变量</h3>

<ul>
  <li><code>PORT</code>: 服务器端口号(默认:3000)</li>
  <li><code>AUTH_TOKEN</code>: 认证令牌(必须,用于API认证)</li>
  <li><code>ROUTE_PREFIX</code>: 路由前缀(可选)</li>
  <li><code>TOKEN_FILE</code>: token文件路径(默认:.token)</li>
  <li><code>TOKEN_LIST_FILE</code>: token列表文件路径(默认:.token-list)</li>
</ul>

<p>更多请查看 <code>/env-example</code></p>

<h3>Token文件格式</h3>

<ol>
  <li>
    <p><code>.token</code> 文件:每行一个token,支持以下格式:</p>

    <pre><code># 这是注释
token1
# alias与标签的作用差不多
alias::token2
</code></pre>

    <p>alias 可以是任意值,用于区分不同的 token,更方便管理,WorkosCursorSessionToken 是相同格式<br>
      该文件将自动向.token-list文件中追加token,同时自动生成checksum</p>
  </li>

  <li>
    <p><code>.token-list</code> 文件:每行为token和checksum的对应关系:</p>

    <pre><code># 这里的#表示这行在下次读取要删除
token1,checksum1
# alias被舍弃,会自动删除最后一个:或%3A的后一位前的所有内容
token2,checksum2
</code></pre>

    <p>该文件可以被自动管理,但用户仅可在确认自己拥有修改能力时修改,一般仅有以下情况需要手动修改:</p>

    <ul>
      <li>需要删除某个 token</li>
      <li>需要使用已有 checksum 来对应某一个 token</li>
    </ul>
  </li>
</ol>

<h3>模型列表</h3>

<p>写死了,后续也不会会支持自定义模型列表</p>

<pre><code>claude-3.5-sonnet
gpt-4
gpt-4o
claude-3-opus
cursor-fast
cursor-small
gpt-3.5-turbo
gpt-4-turbo-2024-04-09
gpt-4o-128k
gemini-1.5-flash-500k
claude-3-haiku-200k
claude-3-5-sonnet-200k
claude-3-5-sonnet-20241022
gpt-4o-mini
o1-mini
o1-preview
o1
claude-3.5-haiku
gemini-exp-1206
gemini-2.0-flash-thinking-exp
gemini-2.0-flash-exp
</code></pre>

<h1>接口说明</h1>

<h2>基础对话</h2>

<ul>
  <li>接口地址: <code>/v1/chat/completions</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: Bearer Token
    <ol>
      <li>使用环境变量 <code>AUTH_TOKEN</code> 进行认证</li>
      <li>使用 <code>.token</code> 文件中的令牌列表进行轮询认证</li>
      <li>在v0.1.3-rc.3支持直接使用 token,checksum 进行认证,但未提供配置关闭</li>
    </ol>
  </li>
</ul>

<h3>请求格式</h3>

<pre><code class="language-json">{
  "model": "string",
  "messages": [
    {
      "role": "system" | "user" | "assistant", // 也可以是 "developer" | "human" | "ai"
      "content": "string" | [
        {
          "type": "text" | "image_url",
          "text": "string",
          "image_url": {
            "url": "string"
          }
        }
      ]
    }
  ],
  "stream": boolean
}
</code></pre>

<h3>响应格式</h3>

<p>如果 <code>stream</code><code>false</code>:</p>

<pre><code class="language-json">{
  "id": "string",
  "object": "chat.completion",
  "created": number,
  "model": "string",
  "choices": [
    {
      "index": number,
      "message": {
        "role": "assistant",
        "content": "string"
      },
      "finish_reason": "stop" | "length"
    }
  ],
  "usage": {
    "prompt_tokens": 0,
    "completion_tokens": 0,
    "total_tokens": 0
  }
}
</code></pre>

<p>不进行 tokens 计算主要是担心性能问题。</p>

<p>如果 <code>stream</code><code>true</code>:</p>

<pre><code>data: {"id":"string","object":"chat.completion.chunk","created":number,"model":"string","choices":[{"index":number,"delta":{"role":"assistant","content":"string"},"finish_reason":null}]}

data: {"id":"string","object":"chat.completion.chunk","created":number,"model":"string","choices":[{"index":number,"delta":{"content":"string"},"finish_reason":null}]}

data: {"id":"string","object":"chat.completion.chunk","created":number,"model":"string","choices":[{"index":number,"delta":{},"finish_reason":"stop"}]}

data: [DONE]
</code></pre>

<h2>Token管理接口</h2>

<h3>简易Token信息管理页面</h3>

<ul>
  <li>接口地址: <code>/tokeninfo</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: HTML页面</li>
  <li>功能: 获取 .token 和 .token-list 文件内容,并允许用户方便地使用 API 修改文件内容</li>
</ul>

<h3>更新Token信息 (GET)</h3>

<ul>
  <li>接口地址: <code>/update-tokeninfo</code></li>
  <li>请求方法: GET</li>
  <li>认证方式: 不需要</li>
  <li>功能: 重新加载tokens并更新应用状态</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "status": "success",
  "message": "Token list has been reloaded"
}
</code></pre>

<h3>更新Token信息 (POST)</h3>

<ul>
  <li>接口地址: <code>/update-tokeninfo</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: Bearer Token</li>
  <li>请求格式:</li>
</ul>

<pre><code class="language-json">{
  "tokens": "string",
  "token_list": "string"
}
</code></pre>

<ul>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "status": "success",
  "token_file": "string",
  "token_list_file": "string",
  "tokens_count": number,
  "message": "Token files have been updated and reloaded"
}
</code></pre>

<h3>获取Token信息</h3>

<ul>
  <li>接口地址: <code>/get-tokeninfo</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: Bearer Token</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "status": "success",
  "token_file": "string",
  "token_list_file": "string",
  "tokens": "string",
  "tokens_count": number,
  "token_list": "string"
}
</code></pre>

<h2>配置管理接口</h2>

<h3>配置页面</h3>

<ul>
  <li>接口地址: <code>/config</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: HTML页面</li>
  <li>功能: 提供配置管理界面,可以修改页面内容和系统配置</li>
</ul>

<h3>更新配置</h3>

<ul>
  <li>接口地址: <code>/config</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: Bearer Token</li>
  <li>请求格式:</li>
</ul>

<pre><code class="language-json">{
  "action": "get" | "update" | "reset",
  "path": "string",
  "content": {
    "type": "default" | "text" | "html",
    "content": "string"
  },
  "enable_stream_check": boolean,
  "include_stop_stream": boolean,
  "vision_ability": "none" | "base64" | "all", // "disabled" | "base64-only" | "base64-http"
  "enable_slow_pool": boolean,
  "enable_all_claude": boolean,
  "check_usage_models": {
    "type": "none" | "default" | "all" | "list",
    "content": "string"
  }
}
</code></pre>

<ul>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "status": "success",
  "message": "string",
  "data": {
    "page_content": {
      "type": "default" | "text" | "html", // 对于js和css后两者是一样的
      "content": "string"
    },
    "enable_stream_check": boolean,
    "include_stop_stream": boolean,
    "vision_ability": "none" | "base64" | "all",
    "enable_slow_pool": boolean,
    "enable_all_claude": boolean,
    "check_usage_models": {
      "type": "none" | "default" | "all" | "list",
      "content": "string"
    }
  }
}
</code></pre>

<p>注意:<code>check_usage_models</code> 字段的默认值为:</p>

<pre><code class="language-json">{
  "type": "default",
  "content": "claude-3-5-sonnet-20241022,claude-3.5-sonnet,gemini-exp-1206,gpt-4,gpt-4-turbo-2024-04-09,gpt-4o,claude-3.5-haiku,gpt-4o-128k,gemini-1.5-flash-500k,claude-3-haiku-200k,claude-3-5-sonnet-200k"
}</code></pre>

<p>这些模型将默认进行使用量检查。您可以通过配置接口修改此设置。</p>

<p>路径修改注意:选择类型再修改文本,否则选择默认时内容的修改无效,在更新配置后自动被覆盖导致内容丢失,自行改进。</p>

<h2>静态资源接口</h2>

<h3>获取共享样式</h3>

<ul>
  <li>接口地址: <code>/static/shared-styles.css</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: CSS文件</li>
  <li>功能: 获取共享样式表</li>
</ul>

<h3>获取共享脚本</h3>

<ul>
  <li>接口地址: <code>/static/shared.js</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: JavaScript文件</li>
  <li>功能: 获取共享JavaScript代码</li>
</ul>

<h3>环境变量示例</h3>

<ul>
  <li>接口地址: <code>/env-example</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: 文本文件</li>
  <li>功能: 获取环境变量配置示例</li>
</ul>

<h2>其他接口</h2>

<h3>获取模型列表</h3>

<ul>
  <li>接口地址: <code>/v1/models</code></li>
  <li>请求方法: GET</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "object": "list",
  "data": [
    {
      "id": "string",
      "object": "model",
      "created": number,
      "owned_by": "string"
    }
  ]
}
</code></pre>

<h3>获取一个随机hash</h3>

<ul>
  <li>接口地址: <code>/get-hash</code></li>
  <li>请求方法: GET</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-plaintext">string</code></pre>

<h3>获取或修复checksum</h3>

<ul>
  <li>接口地址: <code>/get-checksum</code></li>
  <li>请求方法: GET</li>
  <li>请求参数:
    <ul>
      <li><code>checksum</code>: 可选,用于修复的旧版本生成的checksum,也可只传入前8个字符;可用来自动刷新时间戳头</li>
    </ul>
  </li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-plaintext">string</code></pre>

<p>说明:</p>
<ul>
  <li>如果不提供<code>checksum</code>参数,将生成一个新的随机checksum</li>
  <li>如果提供<code>checksum</code>参数,将尝试修复旧版本的checksum以适配v0.1.3-rc.3之后的版本使用,修复失败会返回新的checksum;若输入的checksum本来就有效,则返回更新tsheader后的checksum</li>
</ul>

<h3>获取当前的tsheader</h3>

<ul>
  <li>接口地址: <code>/get-tsheader</code></li>
  <li>请求方法: GET</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-plaintext">string</code></pre>

<h3>健康检查接口</h3>

<ul>
  <li>接口地址: <code>/health</code><code>/</code>(重定向)</li>
  <li>请求方法: GET</li>
  <li>认证方式: Bearer Token(可选)</li>
  <li>响应格式: 根据配置返回不同的内容类型(默认、文本或HTML),默认JSON</li>
</ul>

<pre><code class="language-json">{
  "status": "success",
  "version": "string",
  "uptime": number,
  "stats": {
    "started": "string",
    "total_requests": number,
    "active_requests": number,
    "system": {
      "memory": {
        "rss": number
      },
      "cpu": {
        "usage": number
      }
    }
  },
  "models": ["string"],
  "endpoints": ["string"]
}
</code></pre>

<p>注意:<code>stats</code> 字段仅在请求头中包含正确的 <code>AUTH_TOKEN</code> 时才会返回。否则,该字段将被省略。</p>

<h3>获取日志接口</h3>

<ul>
  <li>接口地址: <code>/logs</code></li>
  <li>请求方法: GET</li>
  <li>响应格式: 根据配置返回不同的内容类型(默认、文本或HTML)</li>
</ul>

<h3>获取日志数据</h3>

<ul>
  <li>接口地址: <code>/logs</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: Bearer Token</li>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "total": number,
  "logs": [
    {
      "id": number,
      "timestamp": "string",
      "model": "string",
      "token_info": {
        "token": "string",
        "checksum": "string",
        "profile": {
          "usage": {
            "premium": {
              "requests": number,
              "requests_total": number,
              "tokens": number,
              "max_requests": number,
              "max_tokens": number
            },
            "standard": {
              "requests": number,
              "requests_total": number,
              "tokens": number,
              "max_requests": number,
              "max_tokens": number
            },
            "unknown": {
              "requests": number,
              "requests_total": number,
              "tokens": number,
              "max_requests": number,
              "max_tokens": number
            }
          },
          "user": {
            "email": "string",
            "name": "string",
            "id": "string",
            "updated_at": "string"
          },
          "stripe": {
            "membership_type": "free" | "free_trial" | "pro" | "enterprise",
            "payment_id": "string",
            "days_remaining_on_trial": number
          }
        }
      },
      "prompt": "string",
      "timing": {
        "total": number,
        "first": number
      },
      "stream": boolean,
      "status": "string",
      "error": "string"
    }
  ],
  "timestamp": "string",
  "status": "success"
}
</code></pre>

<h3>获取用户信息</h3>

<ul>
  <li>接口地址: <code>/userinfo</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: 请求体中包含token</li>
  <li>请求格式:</li>
</ul>

<pre><code class="language-json">{
  "token": "string"
}
</code></pre>

<ul>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "usage": {
    "premium": {
      "requests": number,
      "requests_total": number,
      "tokens": number,
      "max_requests": number,
      "max_tokens": number
    },
    "standard": {
      "requests": number,
      "requests_total": number,
      "tokens": number,
      "max_requests": number,
      "max_tokens": number
    },
    "unknown": {
      "requests": number,
      "requests_total": number,
      "tokens": number,
      "max_requests": number,
      "max_tokens": number
    }
  },
  "user": {
    "email": "string",
    "name": "string",
    "id": "string",
    "updated_at": "string"
  },
  "stripe": {
    "membership_type": "free" | "free_trial" | "pro" | "enterprise",
    "payment_id": "string",
    "days_remaining_on_trial": number
  }
}
</code></pre>

<p>如果发生错误,响应格式为:</p>

<pre><code class="language-json">{
  "error": "string"
}
</code></pre>

<h3>基础校准</h3>

<ul>
  <li>接口地址: <code>/basic-calibration</code></li>
  <li>请求方法: POST</li>
  <li>认证方式: 请求体中包含token</li>
  <li>请求格式:</li>
</ul>

<pre><code class="language-json">{
  "token": "string"
}
</code></pre>

<ul>
  <li>响应格式:</li>
</ul>

<pre><code class="language-json">{
  "status": "success" | "error",
  "message": "string",
  "user_id": "string",
  "create_at": "string",
  "checksum_time": number
}
</code></pre>

<p>注意: <code>user_id</code>, <code>create_at</code>, 和 <code>checksum_time</code> 字段在校验失败时可能不存在。</p>

<h2>偷偷写在最后的话</h2>

<p>虽然作者觉得<del></del>收点钱合理,但不强求,要是<strong>主动自愿</strong>发我我肯定收(因为真有人这么做,虽然不是赞助),赞助很合理吧</p>

<p>不是<strong>主动自愿</strong>就算了,不是很缺,给了会很感动罢了。</p>

<p>虽然不是很建议你赞助,但如果你赞助了,大概可以:</p>

<ul>
  <li>测试版更新</li>
  <li>要求功能</li>
  <li>问题更快解决</li>
</ul>

<p>即使如此,我也保留可以拒绝赞助和拒绝要求的权利。</p>

<p>求赞助还是有点不要脸了,接下来是吐槽:</p>

<p>辛辛苦苦做这个也不知道是为了谁,好累。其实还有很多功能可以做,比如直接传token支持配置(其实这个要专门做一个页面),这个作为rc.4的计划之一吧。</p>

<p>主要没想做用户管理,所以不存在是否接入LinuxDo的问题。虽然那个半成品公益版做好了就是了。</p>

<p>就说这么多,没啥可说的,不管那么多,做就完了。<span>[doge]</span> 自己想象吧。</p>

<p>为什么一直说要跑路呢?主要是有时Cursor的Claude太假了,堪比gpt-4o-mini,我对比发现真没啥差别,比以前差远了,无力了,所以不太想做了。我也感觉很奇怪。</p>

<p>查询额度会在一开始检测导致和完成时的额度有些差别,但是懒得改了,反正差别不大,对话也没响应内容,恰好完成了统一。</p>

<p>有人说少个二维码来着,还是算了。如果觉得好用,给点支持。其实没啥大不了的,没兴趣就不做了。不想那么多了。</p>