mirror of
https://github.com/siteboon/claudecodeui.git
synced 2026-06-03 11:05:35 +08:00
Compare commits
3 Commits
fix/router
...
fix/claude
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
a87214050b | ||
|
|
b988e0da51 | ||
|
|
f132a21cd7 |
19
CHANGELOG.md
19
CHANGELOG.md
@@ -3,6 +3,25 @@
|
|||||||
All notable changes to CloudCLI UI will be documented in this file.
|
All notable changes to CloudCLI UI will be documented in this file.
|
||||||
|
|
||||||
|
|
||||||
|
## [](https://github.com/siteboon/claudecodeui/compare/v1.32.0...vnull) (2026-06-01)
|
||||||
|
|
||||||
|
### New Features
|
||||||
|
|
||||||
|
* add opencode support ([#762](https://github.com/siteboon/claudecodeui/issues/762)) ([374e9de](https://github.com/siteboon/claudecodeui/commit/374e9de71934c41ce2c19c796e35a19234b240ec))
|
||||||
|
* **sidebar:** tooltip for the active-session indicator dot ([#782](https://github.com/siteboon/claudecodeui/issues/782)) ([27e509a](https://github.com/siteboon/claudecodeui/commit/27e509a9b8bb25c35ae0abbda44c536e15c332c8))
|
||||||
|
|
||||||
|
### Bug Fixes
|
||||||
|
|
||||||
|
* **chat:** prevent double send on mobile by removing redundant submit handlers ([#719](https://github.com/siteboon/claudecodeui/issues/719)) ([dbc41dc](https://github.com/siteboon/claudecodeui/commit/dbc41dc91dbf1fb54f92f5536d64646b4e924f31))
|
||||||
|
* preserve WebSocket frame type in plugin proxy ([#594](https://github.com/siteboon/claudecodeui/issues/594)) ([36b860e](https://github.com/siteboon/claudecodeui/commit/36b860e322454df62ebf5309018590b596e6b913)), closes [CoderLuii/HolyClaude#11](https://github.com/CoderLuii/HolyClaude/issues/11)
|
||||||
|
* refine token usage reporting ([#807](https://github.com/siteboon/claudecodeui/issues/807)) ([38bf21d](https://github.com/siteboon/claudecodeui/commit/38bf21ddf554ed28676d86b5221c25adf6f07afd))
|
||||||
|
* refresh Claude auth status after login flow ([#617](https://github.com/siteboon/claudecodeui/issues/617)) ([1e125f3](https://github.com/siteboon/claudecodeui/commit/1e125f3db5248399cd50dc3d40b1f8f44cf7ccb6))
|
||||||
|
* **sidebar:** keep session rename input visible while editing ([#781](https://github.com/siteboon/claudecodeui/issues/781)) ([951f587](https://github.com/siteboon/claudecodeui/commit/951f58751c152fbbb3f8b3ce3c814c06c061de18))
|
||||||
|
|
||||||
|
### Styling
|
||||||
|
|
||||||
|
* fix project star button location by replacing folder icon ([#793](https://github.com/siteboon/claudecodeui/issues/793)) ([295bad9](https://github.com/siteboon/claudecodeui/commit/295bad9c006b669878cbf52940794f29f7370178))
|
||||||
|
|
||||||
## [1.32.0](https://github.com/siteboon/claudecodeui/compare/v1.31.5...v1.32.0) (2026-05-13)
|
## [1.32.0](https://github.com/siteboon/claudecodeui/compare/v1.31.5...v1.32.0) (2026-05-13)
|
||||||
|
|
||||||
### Bug Fixes
|
### Bug Fixes
|
||||||
|
|||||||
@@ -1,218 +0,0 @@
|
|||||||
# CloudCLI UI Nginx subpath deployment template.
|
|
||||||
#
|
|
||||||
# Purpose:
|
|
||||||
# Serve CloudCLI UI from a path prefix such as:
|
|
||||||
# http://localhost/ai/
|
|
||||||
# https://example.com/ai/
|
|
||||||
#
|
|
||||||
# CloudCLI itself still runs at the root of its own HTTP server, for example:
|
|
||||||
# http://127.0.0.1:3001/
|
|
||||||
#
|
|
||||||
# Nginx receives public requests under /ai, strips that prefix, and forwards the
|
|
||||||
# remaining path to CloudCLI. For example:
|
|
||||||
# /ai/ -> /
|
|
||||||
# /ai/session/abc -> /session/abc
|
|
||||||
# /ai/assets/index.js -> /assets/index.js
|
|
||||||
#
|
|
||||||
# Important Nginx limitation:
|
|
||||||
# Nginx does not allow variables in `location` matchers or `rewrite` regexes.
|
|
||||||
# The configurable variables below are still useful for proxy/filter values,
|
|
||||||
# but if you change /ai to a different subpath, also update every line marked:
|
|
||||||
# [SUBPATH LITERAL]
|
|
||||||
#
|
|
||||||
# To use a different subpath, replace these literal matchers:
|
|
||||||
# location = /ai
|
|
||||||
# location ^~ /ai/
|
|
||||||
# rewrite ^/ai(?<cloudcli_path>/.*)$ ...
|
|
||||||
#
|
|
||||||
# Recommended deployment shape:
|
|
||||||
# CloudCLI is the only app using /ai, while root paths /api, /ws, and /shell
|
|
||||||
# are also proxied because the current frontend still calls those endpoints
|
|
||||||
# with root-relative URLs.
|
|
||||||
|
|
||||||
worker_processes 1;
|
|
||||||
|
|
||||||
events {
|
|
||||||
# Maximum simultaneous connections handled by each worker process.
|
|
||||||
# The default is enough for local testing and small self-hosted deployments.
|
|
||||||
worker_connections 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
http {
|
|
||||||
# WebSocket requests include an Upgrade header. Normal HTTP requests do not.
|
|
||||||
# This map gives us the right Connection header for both cases:
|
|
||||||
# Upgrade present -> "upgrade"
|
|
||||||
# Upgrade absent -> "close"
|
|
||||||
map $http_upgrade $connection_upgrade {
|
|
||||||
default upgrade;
|
|
||||||
'' close;
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
# For HTTPS deployments, replace this with `listen 443 ssl http2;` and
|
|
||||||
# add ssl_certificate / ssl_certificate_key lines.
|
|
||||||
listen 80 default_server;
|
|
||||||
|
|
||||||
# Use your real hostname in production, for example:
|
|
||||||
# server_name cloudcli.example.com;
|
|
||||||
server_name localhost 127.0.0.1;
|
|
||||||
|
|
||||||
# ---- User settings -------------------------------------------------
|
|
||||||
#
|
|
||||||
# Public path prefix where users access CloudCLI.
|
|
||||||
# Do not add a trailing slash.
|
|
||||||
#
|
|
||||||
# This variable can be used in redirects and response rewrites. It
|
|
||||||
# cannot be used in `location` matchers, so update the [SUBPATH LITERAL]
|
|
||||||
# lines too if you change it.
|
|
||||||
set $cloudcli_subpath /ai;
|
|
||||||
|
|
||||||
# Private upstream URL where the CloudCLI server is listening.
|
|
||||||
# For a default local server this is usually http://127.0.0.1:3001.
|
|
||||||
set $cloudcli_upstream http://127.0.0.1:3001;
|
|
||||||
|
|
||||||
# Allow larger file uploads through the code editor/project file APIs.
|
|
||||||
client_max_body_size 100m;
|
|
||||||
|
|
||||||
# Redirect /ai to /ai/ so relative browser URL resolution is stable.
|
|
||||||
# [SUBPATH LITERAL] Change `/ai` if you change $cloudcli_subpath.
|
|
||||||
location = /ai {
|
|
||||||
return 301 $cloudcli_subpath/;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Main prefixed CloudCLI UI route.
|
|
||||||
#
|
|
||||||
# [SUBPATH LITERAL] Change `/ai/` and the `^/ai` rewrite if you change
|
|
||||||
# $cloudcli_subpath.
|
|
||||||
location ^~ /ai/ {
|
|
||||||
# Strip the public subpath before proxying. CloudCLI expects to see
|
|
||||||
# root paths such as /, /session/:id, /assets/..., /manifest.json.
|
|
||||||
rewrite ^/ai(?<cloudcli_path>/.*)$ $cloudcli_path break;
|
|
||||||
|
|
||||||
# Forward the rewritten request to the private CloudCLI server.
|
|
||||||
proxy_pass $cloudcli_upstream;
|
|
||||||
|
|
||||||
# Use HTTP/1.1 so WebSocket upgrade requests can pass through if a
|
|
||||||
# browser reaches a socket endpoint under the subpath.
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
|
|
||||||
# Preserve useful request metadata for logs and future app support.
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header X-Real-IP $remote_addr;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
proxy_set_header X-Forwarded-Prefix $cloudcli_subpath;
|
|
||||||
|
|
||||||
# WebSocket upgrade headers. Harmless for normal HTTP requests.
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection $connection_upgrade;
|
|
||||||
|
|
||||||
# Long-running agent and terminal sessions can stay open for a long
|
|
||||||
# time, so avoid closing idle proxied connections too aggressively.
|
|
||||||
proxy_read_timeout 3600s;
|
|
||||||
proxy_send_timeout 3600s;
|
|
||||||
|
|
||||||
# Disable gzip from the upstream response so sub_filter can inspect
|
|
||||||
# and rewrite HTML/JSON/JS response bodies.
|
|
||||||
proxy_set_header Accept-Encoding "";
|
|
||||||
|
|
||||||
# Rewrite browser-visible root-relative URLs so the runtime can
|
|
||||||
# discover that the app is mounted under the subpath.
|
|
||||||
#
|
|
||||||
# Examples:
|
|
||||||
# href="/manifest.json" -> href="/ai/manifest.json"
|
|
||||||
# src="/assets/app.js" -> src="/ai/assets/app.js"
|
|
||||||
#
|
|
||||||
# These rewrites are important for React Router basename detection.
|
|
||||||
sub_filter_once off;
|
|
||||||
sub_filter_types
|
|
||||||
application/json
|
|
||||||
application/manifest+json
|
|
||||||
application/javascript
|
|
||||||
text/javascript;
|
|
||||||
|
|
||||||
sub_filter 'href="/' 'href="$cloudcli_subpath/';
|
|
||||||
sub_filter 'src="/' 'src="$cloudcli_subpath/';
|
|
||||||
|
|
||||||
# The production HTML and JS register the service worker at /sw.js.
|
|
||||||
# Rewrite that registration so the worker is served from /ai/sw.js.
|
|
||||||
sub_filter "register('/sw.js')" "register('$cloudcli_subpath/sw.js')";
|
|
||||||
sub_filter 'register("/sw.js")' 'register("$cloudcli_subpath/sw.js")';
|
|
||||||
|
|
||||||
# The manifest and service worker contain root-relative paths too.
|
|
||||||
# Rewriting them keeps PWA metadata and cached manifest requests
|
|
||||||
# under the same public subpath.
|
|
||||||
sub_filter '"start_url": "/"' '"start_url": "$cloudcli_subpath/"';
|
|
||||||
sub_filter '"scope": "/"' '"scope": "$cloudcli_subpath/"';
|
|
||||||
sub_filter '"src": "/' '"src": "$cloudcli_subpath/';
|
|
||||||
sub_filter "'/manifest.json'" "'$cloudcli_subpath/manifest.json'";
|
|
||||||
sub_filter '"/manifest.json"' '"$cloudcli_subpath/manifest.json"';
|
|
||||||
}
|
|
||||||
|
|
||||||
# Root API proxy.
|
|
||||||
#
|
|
||||||
# The current CloudCLI frontend calls APIs with root-relative URLs such
|
|
||||||
# as /api/auth/login. Keep this location unless the frontend becomes
|
|
||||||
# fully prefix-aware for API requests.
|
|
||||||
location ^~ /api/ {
|
|
||||||
proxy_pass $cloudcli_upstream;
|
|
||||||
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header X-Real-IP $remote_addr;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
proxy_set_header X-Forwarded-Prefix $cloudcli_subpath;
|
|
||||||
|
|
||||||
proxy_read_timeout 3600s;
|
|
||||||
proxy_send_timeout 3600s;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Main app WebSocket proxy.
|
|
||||||
#
|
|
||||||
# The frontend opens /ws for realtime chat/session/task updates.
|
|
||||||
location /ws {
|
|
||||||
proxy_pass $cloudcli_upstream;
|
|
||||||
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection $connection_upgrade;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
proxy_set_header X-Forwarded-Prefix $cloudcli_subpath;
|
|
||||||
|
|
||||||
proxy_read_timeout 3600s;
|
|
||||||
proxy_send_timeout 3600s;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Shell WebSocket proxy.
|
|
||||||
#
|
|
||||||
# The browser terminal uses /shell. It requires the same WebSocket
|
|
||||||
# upgrade handling as /ws.
|
|
||||||
location /shell {
|
|
||||||
proxy_pass $cloudcli_upstream;
|
|
||||||
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection $connection_upgrade;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
proxy_set_header X-Forwarded-Prefix $cloudcli_subpath;
|
|
||||||
|
|
||||||
proxy_read_timeout 3600s;
|
|
||||||
proxy_send_timeout 3600s;
|
|
||||||
}
|
|
||||||
|
|
||||||
# Optional health endpoint proxy used by the frontend version checker.
|
|
||||||
location = /health {
|
|
||||||
proxy_pass $cloudcli_upstream;
|
|
||||||
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto $scheme;
|
|
||||||
proxy_set_header X-Forwarded-Prefix $cloudcli_subpath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
4
package-lock.json
generated
4
package-lock.json
generated
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "@cloudcli-ai/cloudcli",
|
"name": "@cloudcli-ai/cloudcli",
|
||||||
"version": "1.32.0",
|
"version": "1.33.0",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "@cloudcli-ai/cloudcli",
|
"name": "@cloudcli-ai/cloudcli",
|
||||||
"version": "1.32.0",
|
"version": "1.33.0",
|
||||||
"hasInstallScript": true,
|
"hasInstallScript": true,
|
||||||
"license": "AGPL-3.0-or-later",
|
"license": "AGPL-3.0-or-later",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@cloudcli-ai/cloudcli",
|
"name": "@cloudcli-ai/cloudcli",
|
||||||
"version": "1.32.0",
|
"version": "1.33.0",
|
||||||
"description": "A web-based UI for Claude Code CLI",
|
"description": "A web-based UI for Claude Code CLI",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"main": "dist-server/server/index.js",
|
"main": "dist-server/server/index.js",
|
||||||
|
|||||||
@@ -83,6 +83,10 @@ export class ClaudeProviderAuth implements IProviderAuth {
|
|||||||
private async checkCredentials(): Promise<ClaudeCredentialsStatus> {
|
private async checkCredentials(): Promise<ClaudeCredentialsStatus> {
|
||||||
const missingCredentialsError = 'Claude CLI is not authenticated. Run claude /login or configure ANTHROPIC_API_KEY.';
|
const missingCredentialsError = 'Claude CLI is not authenticated. Run claude /login or configure ANTHROPIC_API_KEY.';
|
||||||
|
|
||||||
|
if (process.env.ANTHROPIC_AUTH_TOKEN?.trim()) {
|
||||||
|
return { authenticated: true, email: 'Auth Token', method: 'api_key' };
|
||||||
|
}
|
||||||
|
|
||||||
if (process.env.ANTHROPIC_API_KEY?.trim()) {
|
if (process.env.ANTHROPIC_API_KEY?.trim()) {
|
||||||
return { authenticated: true, email: 'API Key Auth', method: 'api_key' };
|
return { authenticated: true, email: 'API Key Auth', method: 'api_key' };
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user