代码拉取完成,页面将自动刷新
同步操作将从 luyoyu/share-copilot 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
更新代码补全接口代理:代码补全代理说明
简单说一下
本地插件的请求逻辑:
1.本地插件携ghu_token 请求github的API
2.返回带有时间戳的copilot的token(简称co_token),
代码提示都是用的co_token
3.co_token到期->ghu_token重新请求->获得新的co_token
-------------------------------------------------------------
代理服务器的逻辑:
代理的是"ghu_token请求"这一环节
1.使用ghu_token请求github的API,暂存co_token
2.多用户请求时,判断co_token有没有过期,没过期直接返回co_token,
减少对ghu_token的请求次数(大约10-20分钟过期)
3.至于本地co_token,也就是代码提示没有走代理(可以代理,但是要修改插件,jetbrains的插件还要重新build)
猜测风控目前也只是停留在请求ghu_token这一层
"cocopilot也是代理了ghu_token请求,并没有破解插件"
| 文件名 | 说明
| -------------- | -------------------
| config.json | 配置文件
| copilot_api | guh_token和co_token相关逻辑
| global | 全局变量、常量或配置
| main | 主要入口文件
| middleware | 中间件,验证域名,验证自定义请求头
| routers | 路由信息,定义不同请求路径的处理逻辑。
| server | 服务端的代码或相关配置,用于启动和运行服务器。
| show_msg | 用于显示消息或信息的函数,展示内容。
测试环境:Linux4.18.0-305.3.1.el8.x86_64 GNU/Linux
需要 go环境 出问题自行chatgpt
git clone https://gitee.com/chuangxxt/share-copilot.git
wget https://dl.google.com/go/go1.21.1.linux-amd64.tar.gz
tar -C /usr/local -xzf go1.21.1.linux-amd64.tar.gz
vim ~/.bashrc
#添加下列环境
export PATH=$PATH:/usr/local/go/bin
export GOPATH=$HOME/go
export PATH=$PATH:$GOPATH/bin
#使生效环境变量
source ~/.bashrc
#验证go配置
go version
#cd到main.go源码目录
cd /share-copilot/src
go build
wget https://gitee.com/chuangxxt/share-copilot/releases/download/v2.0.4/share-copilot-linux-amd64.zip
unzip share-copilot-linux-amd64.zip
cd share-copilot
bash install.sh
vim config.json #修改配置信息
domain//监听域名或ip 可用nginx反代
host //ip
port //端口 80或443
certPath//公钥路径-443必须
keyPath//私钥路径-443必须
github_api_url//默认不改
token//自己的副驾驶token,可放多个,请求时随机使用
//登录插件后在%userprofile%\AppData\Local\github-copilot\hosts.json ghu_开头
verification//自定义验证
{
"server": {
"domain": "example.com",
"host": "0.0.0.0",
"port": 443,
"certPath":"./example.pem",
"keyPath":"./example.pem"
},
"copilot_config":{
"github_api_url": "https://api.github.com/copilot_internal/v2/token",
"token":[
"yours_token_1",
"yours_token_2",
"yours_token_3"
]},
"verification":"",
"diyMsg":"",
"isModMsg":false
}
格式不能错,不确定的去这里验证 ->https://www.json.cn/
scop r #运行 [Ctrl+c退出] 如果运行失败添加可执行权限 chmod +x share-copilot
scop rb #后台运行
scop st #停止
scop v #查看是否运行
{
"server": {
"domain": "api.example.com",
"host": "0.0.0.0",
"port": 443,
"certPath":"./example.pem",
"keyPath":"./example.pem"
},
"copilot_config":{
"github_api_url": "https://api.github.com/copilot_internal/v2/token",
"token":[
"ghu_xMNAYLcJAPqAfiGoobrWffkJoNcGMVJtETKA",
"ghu_GZgKFwraHorAxXXUvsUclOhxiYERPsSJeNuF",
"ghu_SPUTCLvkMKoeMstPJmhSlYsYvCojhkFjGubl"
]},
"verification":"i_am_free",
"diyMsg":"",
"isModMsg":false
}
Jetbrains -- 用于Jetbrains插件
Vscode -- 用于Vscode插件
Valid tokens: -- 配置里面有效的token数量
Succeed: -- 插件请求代理成功次数
Failed: -- 插件请求代理失败次数
GithubApi: --服务器请求gh_api次数
正常情况下 GithubApi < Succeed 因为请求的Token 几十分钟才过期
以windows为例
{
"github.com":{
"user":"suibian",//随意填写
"oauth_token":"i_am_free",//与上面verification对应
"dev_override":{
"copilot_token_url":"https://api.example.com/copilot_internal/v2/token"
//你的地址
}
}
}
//添加下列代码,注意vscode插件更新需要重新添加,jetbrains则不用
process.env.GITHUB_TOKEN="i_am_free"; //与上面verification对应
process.env.GITHUB_API_URL="https://api.example.com"; //你的地址
process.env.CODESPACES="true";
process.env.GITHUB_SERVER_URL="https://github.com";
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。