当前位置: 首页 > news >正文

opencode会话同步skill

Session Sync

OpenCode 会话同步工具 - 将会话导出保存到 GitHub/Gitee Gist,或从 Gist 拉取历史会话并导入本地。

仓库地址:skills: skill合集

功能特性

  • 📤上传会话:将当前或指定的 OpenCode 会话导出为 JSON,上传/更新到 Gist
  • 📥恢复会话:从 Gist 下载历史会话 JSON 并导入到当前项目
  • 🔧自动管理 Gist ID:每个项目独立管理自己的 Gist 映射,无需用户记忆
  • 🖥️跨平台支持:支持 Linux、macOS 和 Windows
  • 🔒安全可靠:Gist 默认为私有,保护您的会话内容

安装

全局安装(推荐)

# 复制session-sync到全局 skill 目录cp-rsession-sync ~/.config/opencode/skills/session-sync

项目本地安装

# 复制session-sync到项目本地 skill 目录cp-rsession-sync ./.opencode/skills/session-sync

目录结构

session-sync/ ├── SKILL.md # 技能说明文档(Agent 使用) ├── README.md # 本文件 └── scripts/ ├── sync.sh # Linux/macOS 同步脚本 └── sync.ps1 # Windows 同步脚本

前置配置

1. 配置 API Token

在使用前,需要配置 GitHub 或 Gitee 的 API Token:

Linux/macOS:(Linux可以写入到.bashrc文件)

# 使用 Gitee(默认)exportGITEE_TOKEN="your-gitee-token"# 或使用 GitHubexportGITHUB_TOKEN="your-github-token"exportOPENCODE_SYNC_PLATFORM="github"

Windows (PowerShell):(Windows可以通过环境变量设置)

# 使用 Gitee(默认)$env:GITEE_TOKEN ="your-gitee-token"# 或使用 GitHub$env:GITHUB_TOKEN ="your-github-token"$env:OPENCODE_SYNC_PLATFORM ="github"

💡获取 Token

  • GitHub: Settings → Developer settings → Personal access tokens → Tokens (classic)
  • Gitee: 设置 → 私人令牌 → 生成新令牌
  • 只需勾选gist权限

2. 配置 Gist ID

方式一:环境变量(推荐)

Linux/macOS:

exportOPENCODE_SYNC_GIST_ID="your-gist-id"

Windows (PowerShell):

$env:OPENCODE_SYNC_GIST_ID ="your-gist-id"

方式二:映射文件

在项目根目录创建.session-gist.json

{"gist_id":"your-gist-id","platform":"gitee"}

💡获取 Gist ID

  1. 访问 https://gitee.com 或 https://gist.github.com
  2. 创建一个新的 Gist(可以是空的)
  3. 从 URL 中复制 Gist ID,例如:
    • URL:https://gist.github.com/username/abc123def456
    • Gist ID:abc123def456

使用方式

上传会话(Push)

将当前或指定的会话上传到 Gist:

Linux/macOS:

# 上传当前会话(最近一个)bash~/.config/opencode/skills/session-sync/scripts/sync.sh push# 上传指定会话bash~/.config/opencode/skills/session-sync/scripts/sync.sh push ses_xxx

Windows:

# 上传当前会话(最近一个)~/.config/opencode/skills/session-sync/scripts/sync.ps1 push# 上传指定会话~/.config/opencode/skills/session-sync/scripts/sync.ps1 push ses_xxx

恢复会话(Pull)

从 Gist 下载并恢复会话:

Linux/macOS:

# 列出 Gist 中的所有会话文件bash~/.config/opencode/skills/session-sync/scripts/sync.sh pull# 恢复指定会话bash~/.config/opencode/skills/session-sync/scripts/sync.sh pull"projectname-sessiontitle.json"

Windows:

# 列出 Gist 中的所有会话文件~/.config/opencode/skills/session-sync/scripts/sync.ps1 pull# 恢复指定会话~/.config/opencode/skills/session-sync/scripts/sync.ps1 pull"projectname-sessiontitle.json"

恢复后,使用以下命令继续会话:

opencode--continue# 或opencode--session<session-id>

列出现有会话

Linux/macOS:

bash~/.config/opencode/skills/session-sync/scripts/sync.sh list

Windows:

~/.config/opencode/skills/session-sync/scripts/sync.ps1 list

工作流程示例

场景一:备份当前会话

# 1. 配置环境变量exportGITEE_TOKEN="your-token"exportOPENCODE_SYNC_GIST_ID="your-gist-id"# 2. 上传当前会话bashscripts/sync.sh push# 输出:# [session-sync] 项目: myproject# [session-sync] 正在导出会话: ses_xxx ...# [session-sync] 正在更新现有 Gist: abc123 ...# [session-sync] 已更新: https://gist.github.com/abc123

场景二:在新电脑上恢复会话

# 1. 配置环境变量exportGITEE_TOKEN="your-token"exportOPENCODE_SYNC_GIST_ID="your-gist-id"# 2. 列出可用的会话文件bashscripts/sync.sh pull# 输出:# Gist 中可用的会话文件:# 1. myproject-feature1.json# 2. myproject-bugfix.json# 3. 恢复指定会话bashscripts/sync.sh pull"myproject-feature1.json"# 4. 继续会话opencode--continue

场景三:跨平台同步

在 macOS 上上传:

exportGITEE_TOKEN="your-token"exportOPENCODE_SYNC_GIST_ID="your-gist-id"bashscripts/sync.sh push

在 Windows 上下载:

$env:GITEE_TOKEN ="your-token"$env:OPENCODE_SYNC_GIST_ID ="your-gist-id"scripts/sync.ps1 pull"myproject-session.json"

环境变量参考

变量名必需默认值说明
GITEE_TOKEN是*-Gitee API 令牌(使用 Gitee 时)
GITHUB_TOKEN是*-GitHub API 令牌(使用 GitHub 时)
OPENCODE_SYNC_PLATFORMgitee平台选择:giteegithub
OPENCODE_SYNC_GIST_ID-Gist ID(可选,也可通过映射文件配置)

*使用对应平台时必需

文件说明

  • .session-gist.json:保存在项目根目录,记录该项目对应的 Gist ID 和平台信息。建议将其加入.gitignore
  • 会话 JSON 文件:上传时会自动命名为<project-name>-<session-title>.json

注意事项

  1. Gist ID 不会自动创建:脚本永远不会自动创建新的 Gist,必须由用户明确提供 Gist ID。
  2. 会话 ID 自动添加:导出时会自动添加id字段,确保可以成功导入。
  3. 项目隔离:每个项目的 Gist 映射文件保存在各自的项目根目录,互不干扰。
  4. 平台选择:默认使用 Gitee,如需使用 GitHub,请设置OPENCODE_SYNC_PLATFORM=github

故障排除

错误:缺少 Token

错误:缺少 Token。请设置 GITHUB_TOKEN 或 GITEE_TOKEN 环境变量。

解决:按照前置配置步骤配置 API Token。

错误:未配置 Gist ID

错误:项目 'xxx' 未配置 Gist ID。

解决:按照配置 Gist ID步骤配置 Gist ID。

错误:Missing key at [“id”]

解决:此问题已在最新版本中修复。请确保使用最新版本的脚本,导出时会自动添加id字段。

http://www.jsqmd.com/news/778985/

相关文章:

  • 【图像加密解密】3D-IWT和2D-ICSM超混沌的密文彩色图像加密解密【含Matlab源码 15420期】
  • Claude Skills 完全使用指南:从入门到自定义开发
  • AI代码生成:告别重复开发,效率翻倍
  • 面试被问 MySQL 慢 SQL 怎么排查?看完这篇直接给面试官讲明白
  • 项目介绍 基于Python的汉服商城管理系统设计与实现(含模型描述及部分示例代码)专栏近期有大量优惠 还请多多点一下关注 加油 谢谢 你的鼓励是我前行的动力 谢谢支持 加油 谢谢
  • stm32f103编程手册英文版中,常用词汇生成英文短文学习
  • 2026国内葡萄牙移民中介五大排名:怎么选一个靠谱葡萄牙移民中介? - 速递信息
  • 量子计算中的对称保护拓扑序:理论与硬件实现
  • 宇树科技开放全球首个机器人应用商店,推动人形机器人迈向智能机时代
  • 2026年5月7日 AI发展对卫星通讯的影响及太空算力中心建设与发展深度研究
  • 字基网络芯片:让“成人的AI”走进物理世界 ——AGI芯片的终极范式革命
  • 数智赋能精准监测,合众思壮旗下吉欧电子亮相第八届工程监测技术大会 - 速递信息
  • 【视网膜病变】LBP检测糖尿病视网膜病变【含GUI Matlab源码 15421期】
  • 避坑指南:在Keil MDK中为STM32G4系列正确配置IQmathLib(解决常见链接错误)
  • 零基础学 Python 第一天|从环境搭建到基础语法,保姆级复盘
  • 16QAM调制与LO相位噪声的工程挑战与解决方案
  • 圣诞手势特效指挥 圣诞节交互魔法树项目源码
  • 单调有界定理等
  • 【超详细】一文吃透STM32F103定时器中断配置,零基础也能跟着上手附全过程工程代码
  • 一键下载恢复IE 浏览器?链接在这里
  • OBBDetection环境配置步骤
  • Token需求狂飙千倍,22亿热钱涌向这家AGI Infra头号玩家
  • 基于AI的咨询式PPT大纲生成:从文本到结构化汇报的自动化实践
  • 上海踏信冷链:为头部生鲜餐饮品牌护航,专业第三方冷链物流解决方案 - 速递信息
  • 有没有微软出品的 Kubernetes 学习路线推荐?
  • opencode安装,无root
  • 自己画LAN8720板子,网口死活不通?别急着怀疑代码,先检查这4个不起眼的电容
  • 扣子实战:告别剪辑熬夜!Seedance2.0 联动扣子,一键生成专业口播电商带货短视频
  • 从码农到架构师:Boss-Skill项目揭示全栈开发者进阶之路
  • 2026年4月仿古砖公司推荐,仿古砖提升家居整体质感 - 品牌推荐师