
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
https://travis-ci.org/o2r-project/o2r-bouncer.svg?branch=master](https://travis-ci.org/o2r-project/o2r-bouncer) https://images.microbadger.com/badges/version/o2rproject/o2r-bouncer.svg](https://microbadger.com/images/o2rproject/o2r-bouncer "Get your own version badge on microbadger.com")
o2r-bouncer是o2r API基于OAuth2的认证流程的Node.js实现。
该镜像提供o2r平台的用户身份验证功能,支持ORCID登录、会话管理,并可集成Slack机器人进行状态通知和用户事件提醒。
bash# 构建镜像 docker build -t bouncer . # 启动MongoDB容器 docker run --name mongodb -d mongo:3.4 # 启动bouncer容器(需替换环境变量值) docker run --name testbouncer -it -p 8383:8083 --link mongodb:mongodb \ -e OAUTH_CLIENT_ID=你的客户端ID \ -e OAUTH_CLIENT_SECRET=你的客户端密钥 \ -e OAUTH_STARTUP_TEST=false \ -e BOUNCER_MONGODB=mongodb://mongodb:27017 \ -e DEBUG=* \ bouncer
BOUNCER_PORT:监听端口,默认8083BOUNCER_MONGODB(必填):MongoDB连接地址,默认mongodb://localhost:27017/BOUNCER_MONGODB_DATABASE:使用的数据库名,默认muncherBOUNCER_DEFAULT_USER_LEVEL:新用户注册时的默认用户级别,默认100(已知用户)OAUTH_URL_AUTHORIZATION:ORCID OAuth2授权URL,默认用于o2r-guestlister的http://localhost:8383/oauth/authorizeOAUTH_URL_TOKEN:ORCID OAuth2令牌URL,默认用于o2r-guestlister的http://localhost:8383/oauth/tokenOAUTH_SCOPE:ORCID API权限范围,默认/authenticateOAUTH_CLIENT_ID(必填):实例的客户端IDOAUTH_CLIENT_SECRET(必填):实例的客户端密钥http_proxy(必填):OAuth流程使用的HTTP(S)代理(服务器在代理/防火墙后时需要)SLACK_BOT_TOKEN:Slack机器人认证令牌SLACK_VERIFICATION_TOKEN:Slack交互消息验证令牌SLACK_CHANNEL_STATUS:状态消息发布频道,默认#monitoringSLACK_CHANNEL_USER:用户事件消息发布频道,默认#monitoringSLACK_USERNAMES_WHITELIST:允许响应交互消息的Slack用户名正则表达式,默认.*(不限制)1:连接MongoDB的最大尝试次数已达4:OAuth凭据配置缺失5:OAuth启动测试失败参考ORCID文档:访问公共API和ORCID iD登录。需设置重定向URI为/api/v1/auth/login(相对于你的基础URL),推荐使用HTTPS。客户端ID和密钥需通过环境变量或config/config.js文件提供。
使用o2r-guestlister离线OAuth2实现时,客户端ID和密钥需与o2r-guestlister一致。
使用https://github.com/expressjs/session%E4%B8%AD%E9%97%B4%E4%BB%B6%E7%AE%A1%E7%90%86%E7%99%BB%E5%BD%95%E7%94%A8%E6%88%B7%E3%80%82%E7%94%A8%E6%88%B7%E9%80%9A%E8%BF%87%60/api/v1/auth/login%60%E7%99%BB%E5%BD%95%E5%90%8E%EF%BC%8C%E4%BC%9A%E8%AF%9Dcookie%E4%BC%9A%E5%AD%98%E5%82%A8%E5%9C%A8%E6%95%B0%E6%8D%AE%E5%BA%93%E4%B8%AD%EF%BC%8C%E5%AE%A2%E6%88%B7%E7%AB%AF%E9%80%9A%E8%BF%87%E8%AF%A5cookie%E6%8C%81%E7%BB%AD%E8%AE%BF%E9%97%AEo2r%E5%B9%B3%E5%8F%B0%E3%80%82
Slack API文档:[***]
机器人需要以下权限:
channels:writechat:write:botincoming-webhookbot在Slack的交互式消息配置页面,设置以下端点:
https://你的域名/api/v1/auth/slack/actionhttps://你的域名/api/v1/auth/slack/options-load需通过环境变量提供必填设置,例如:
bashDEBUG=* OAUTH_CLIENT_ID=你的ID OAUTH_CLIENT_SECRET=你的密钥 SLACK_VERIFICATION_TOKEN=你的令牌 SLACK_BOT_TOKEN=xoxb-你的令牌 npm start
访问http://localhost:8083/api/v1/auth/login开始认证流程,访问http://localhost:8083/api/v1/auth/whoami查看当前用户信息。
o2r bouncer基于Apache License 2.0许可,详见LICENSE文件。
版权所有 (C) 2016 - o2r项目。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务