开源的 Steam 自动收发货解决方案
杜绝收费、安全稳定
广告: 【ECOSteam】复制整段打开ECOSteam加入「Elsa可达鸭」PN:01J0TGJPQZF7G9FK0P6QJWQGRJ「欢迎加入Elsa可达鸭的团队或点击链接https://share.ecosteam.cn/share/01J0TGJPQZF7G9FK0P6QJWQGRJ「欢迎加入Elsa可达鸭的团队
ECOSteam 新CSGO皮肤交易平台
交易0手续费 提现1% 加入团队金额前10我还额外赠送免费提现券(20000元)
货多的还可以联系群管申请交易补贴!(2%)
可租可售 上架就有利息拿 最高可拿15%利息 加入我的团队拿额外2%利息(总金额要求已经达到 只需要人数)
本软件完美支持ECOSteam, 请放心使用
使用前请仔细阅读本文档!
欢迎有能力者提交PR来完善本程序。
请勿违反开源协议,包括但不限于闭源倒卖此程序或修改后不进行开源等。
欢迎加入Steamauto 官方QQ群:425721057
网络不好的可以加QQ群在群文件内下载最新构建
强烈谴责平头哥CSGO违反开源协议闭源修改本软件并收费出售, 我们将对其采取行动 快照证据
在 Buff饰品交易平台 上:
- 自动发货
- 自动求购收货(需要开启 自动接受礼物报价 功能)
- 供应求购确认报价
- 以最低价上架全部库存
- 支持自动上架描述
- 支持自动上架时间段黑白名单
- 支持选择塞给求购订单, 利益最大化
在 悠悠有品饰品交易平台 上:
- 自动发货出售商品
在 ECOSteam交易平台 上:
- 自动发货
- 与BUFF上架商品同步 (支持比例)
- 内置Steam加速器
- 自动接受礼物报价(无需支出任何Steam库存中的物品的报价)
推荐观看视频教程
0. 给予本仓库一个star(手动狗头)
- 前往 Github Releases 下载适合自己系统的Steamauto
- 运行一次程序,程序会释放配置文件
- 编辑
config
文件夹下的config.json5
(相关教程见FAQ) - 修改
config
文件夹下的steam_account_info.json5
中所有的参数(相关教程见配置说明) - (若有需求Buff相关功能) 在
config.json5
中启用BUFF相关功能并直接运行程序(程序会自动填写buff_cookies.txt) - (若有需求悠悠有品相关功能) 打开
uu_token.txt
,填入悠悠有品的token(如何获取token,见FAQ)
部分配置项数据(如获取Steam账户信息、Buff的cookie等)在附录中,请自行查阅!
文件名 | 描述 |
---|---|
config.json5 |
主配置文件,可以修改程序的大多数设置 |
steam_account_info.json5 |
用于填入Steam账户相关信息 |
buff_cookies.txt |
启用网易Buff相关插件后才会创建 用于存取网易BUFF的Cookie信息 |
uu_token.txt |
启用悠悠有品相关插件后才会创建 用于存取悠悠有品的Cookie信息(悠悠有品token获取方法见FAQ) |
config.json5 (仅供参考 以实际文件为主)
{
// 登录Steam时是否开启SSL验证,正常情况下不建议关闭SSL验证
"steam_login_ignore_ssl_error": false,
// 是否开启本地加速功能
// 本地加速功能并非100%可用, 若开启后仍然无法正常连接Steam属于正常情况, 最优解决方案是使用海外服务器
// 请注意:开启此功能必须关闭Steam登录SSL验证,即steam_login_ignore_ssl_error必须设置为true
"steam_local_accelerate": false,
// 是否使用Steam代理功能(该功能只会代理Steam)
"use_proxies": false,
// 本地代理地址, 使用前需要确保use_proxies已经设置为true
// 这里以clash为例,clash默认监听7890端口,如果你使用的是其他代理软件,请自行修改端口
"proxies": {
"http": "http://127.0.0.1:7890",
"https": "http://127.0.0.1:7890"
},
// 填写为true后,程序在出现错误后就会直接停止运行。如果你不知道你在做什么,请不要将它设置为true
"no_pause": false,
// BUFF 自动发货插件配置
"buff_auto_accept_offer": {
// 是否启用BUFF自动发货报价功能
"enable": true,
// 每次检查是否有新报价的间隔(轮询间隔),单位为秒
"interval": 300,
// 是否开启出售保护(自动发货前检查其他卖家最低价,若低于保护价格则不会自动接受报价s)
"sell_protection": false,
// 出售保护价格,若其他卖家最低价低于此价格,则不会进行出售保护
"protection_price": 30,
// 出售价格保护比例,若出售价格低于此比例乘以其他卖家最低价格,则不会自动接受报价
"protection_price_percentage": 0.9,
// 出售通知配置(如不需要可直接删除)
"sell_notification": {
// 出售通知标题
"title": "成功出售{game}饰品: {item_name} * {sold_count}",
// 出售通知内容
"body": "![good_icon]({good_icon})\n游戏: {game}\n饰品: {item_name}\n出售单价: {buff_price} RMB\nSteam单价(参考): {steam_price} USD\nSteam单价(参考): {steam_price_cny} RMB\n![buyer_avatar]({buyer_avatar})\n买家: {buyer_name}\n订单时间: {order_time}"
},
// 出售保护通知配置(如不需要可直接删除)
"protection_notification": {
// 出售保护通知标题(如不需要可直接删除)
"title": "{game}饰品: {item_name} 未自动接受报价, 价格与市场最低价相差过大",
// 出售保护通知内容(如不需要可直接删除)
"body": "请自行至BUFF确认报价!"
},
// 报价与BUFF出售商品不匹配通知配置(如不需要可直接删除)
"item_mismatch_notification": {
// 报价与BUFF出售商品不匹配通知标题
"title": "BUFF出售饰品与Steam报价饰品不匹配",
// 报价与BUFF出售商品不匹配通知内容
"body": "请自行至BUFF确认报价!(Offer: {offer_id})"
},
// BUFF Cookies失效通知配置
"buff_cookie_expired_notification": {
// BUFF Cookies失效通知标题(如不需要可直接删除)
"title": "BUFF Cookie已过期, 请重新登录",
// BUFF Cookies失效通知内容(如不需要可直接删除)
"body": "BUFF Cookie已过期, 请重新登录"
},
// 二维码登录BUFF通知配置
"buff_login_notification": {
// 二维码登录BUFF通知标题(如不需要可直接删除)
"title": "请扫描二维码登录BUFF",
// 是否开启传递 二维码图片
"include_qrcode_html_enable": false
},
// 通知服务器列表,使用Apprise格式,详见https://github.com/caronc/apprise/
"servers": [
]
},
// BUFF 自动备注购买价格插件配置
"buff_auto_comment": {
// 是否启用BUFF自动备注购买价格功能
"enable": true
},
// BUFF 自动计算利润插件配置
"buff_profit_report": {
// 是否启用BUFF自动计算利润功能
"enable": false,
// 通知服务器列表,使用Apprise格式,详见https://github.com/caronc/apprise/
"servers": [
],
// 每日发送报告时间, 24小时制
"send_report_time": "20:30"
},
// BUFF 自动上架插件配置
"buff_auto_on_sale": {
// 是否启用BUFF自动以最低价上架所有库存
"enable": false,
// 每次检查库存强制刷新BUFF库存, 若为否, 刷新不一定会加载最新库存
"force_refresh": true,
// 使用磨损区间最低价上架, 若为否, 则使用类型最低价上架
// 注意: 该功能会导致增加更多的请求, 请谨慎开启
"use_range_price": false,
// 黑名单时间, 为小时, int格式, 空为不启用黑名单, 当前小时如果等于黑名单时间, 则不会自动上架
"blacklist_time": [],
// 白名单时间, 为小时, int格式, 空为不启用白名单, 当前小时如果不等于白名单时间, 则不会自动上架
"whitelist_time": [],
// 随机上架几率, 为整数, 1~100, 100为100%上架, 1为1%上架, 0为不上架
"random_chance": 100,
// 商品上架描述, 为字符串, 为空则不填写描述
"description": "",
// 检查库存间隔时间
"interval": 1800,
// 每个请求间隔时间 (秒) - 用于防止被BUFF封禁
"sleep_seconds_to_prevent_buff_ban": 10,
// 供应求购相关配置
"buy_order": {
// 是否供应求购订单
"enable": true,
// 是否只供应给开启自动收货的求购订单
"only_auto_accept": true,
// 支持收款方式 支付宝 微信
"supported_payment_method": ["支付宝"],
// 低于多少金额的商品直接塞求购
"min_price": 5
},
// 上架通知配置(如不需要可直接删除)
"on_sale_notification": {
// 上架通知标题
"title": "游戏 {game} 成功上架 {sold_count} 件饰品",
// 上架通知内容
"body": "上架详情:\n{item_list}"
},
// 出现验证码通知配置(如不需要可直接删除)
"captcha_notification": {
// 出现验证码通知标题
"title": "上架饰品时出现验证码",
// 出现验证码通知内容
"body": "使用session={session}并使用浏览器打开以下链接并完成验证:\n{captcha_url}"
},
// 通知服务器列表,使用Apprise格式,详见https://github.com/caronc/apprise/
"servers": [
]
},
// 悠悠有品自动发货插件配置
"uu_auto_accept_offer": {
// 悠悠有品自动发货功能是否启用,默认为false
"enable": false,
// 每次检查是否有新报价的间隔(轮询间隔),单位为秒
"interval": 300
},
// Steam 自动接受礼物报价插件配置
"steam_auto_accept_offer": {
// 是否开启自动接受Steam礼物报价(无需支出任何Steam库存中的物品的报价)
"enable": false,
// 每次检查报价列表的间隔(轮询间隔),单位为秒
"interval": 300
},
// ECOSteam.cn 插件配置
// 请提前接入开放平台 RSAKey请放置在config目录下的rsakey.txt文件中
"ecosteam": {
"enable": false,
"partnerId": "", // 必填!用于登录ECOsteam平台
"auto_accept_offer": {
"interval": 30
},
"auto_sync_sell_shelf": { // 自动同步各平台的上架商品, 与主平台一致, 目前仅支持buff
"enable": false,
"main_platform": "buff", // 填buff或eco,不可以填其它内容!
"enabled_platforms": ["buff"], // 由于目前仅支持buff, 所以该配置项请保持不变
"ratio":{ // 各平台上架价格的比例
"eco" : 0.98,
"buff" : 1
},
"interval": 60 // 不建议设置太长,因为同步上架带来的问题是ECO发货后BUFF未及时下架,如果此时有人购买库存中没有的饰品,可能会导致BUFF封号
},
"qps": 10 //每秒最大请求数。如果你是白名单大会员,建议设置为30。如果你不知道这是什么,请保持默认值。
},
// 是否开启开发者模式,具体功能请查看代码,非开发者请勿开启!开启后无法正常使用!!!
"development_mode": false
}
{
// 新版Steamauto已经无需手动填写API_KEY、steamid、buff_cookies.txt(均可自动获取),视频教程暂未更新,请悉知!!!
// 新版Steamauto已经无需手动填写API_KEY、steamid、buff_cookies.txt(均可自动获取),视频教程暂未更新,请悉知!!!
// 新版Steamauto已经无需手动填写API_KEY、steamid、buff_cookies.txt(均可自动获取),视频教程暂未更新,请悉知!!!
// Steam 令牌参数(用于身份验证)
"shared_secret": "",
// Steam 令牌参数(用于身份验证)
"identity_secret": "",
// Steam 登录时填写的用户名
"steam_username": "",
// Steam 登录时填写的密码
"steam_password": ""
}
配置项 | 描述 |
---|---|
sell_notification | 出售通知(如不需要可直接删除) |
protection_notification | 出售保护通知(如不需要可直接删除) |
item_mismatch_notification | 报价与BUFF出售商品不匹配通知配置(如不需要可直接删除) |
buff_cookie_expired_notification | BUFF Cookies失效通知(如不需要可直接删除) |
--- | --- |
title | 通知标题 |
body | 通知内容 |
servers | Apprise格式服务器列表 - 详见Apprise - 额外支持 Server酱 格式为 ftqq://<SENDKEY> - 额外支持 pushplus 格式为 pushplus://<token> |
Steamauto的所有源代码均开放在GitHub,可供所有人自行查看代码安全性
在用户的电脑不被恶意软件入侵的情况下,账号不可能泄露
本程序使用的配置文件类型为json5,因此在不受支持编辑器中会提示语法错误,但实际上并不影响程序的运行
不支持,但是有以下解决方案。
在BUFF上,你可以打开BUFF网页版的个人设置页面,并勾上偏好设置中的出售限定买家先发报价
在悠悠有品上,暂无解决方案,你需要手动处理
使用-uu
参数或者在程序所在目录下创建uu.txt
(无需填入任何内容),运行Steamauto程序,根据程序向导操作即可
支持。但是需要复制多份程序,分别在不同的文件夹内运行
如果你只需要Buff自动发货多开,你也可以尝试支持多账户的Fork版本
将config.json
中buff_auto_accept_offer.enable
设置为false即可
该错误在特定urllib
下会出现,安装特定版本可以解决
pip install urllib3==1.25.11
steampy/client.py
44-48行注释掉的代码解除注释后若出现报错则说明是此问题
关于steam_account_info.json
相关参数的获取教程都在下面, 请自行参阅
个人推荐使用 SteamDesktopAuthenticator(简称SDA) 获取Steam令牌参数 操作简便(请勿使用1.0.13版本,存在无法获取的问题)
官方视频教程
已Root安卓手机获取新版Steam手机令牌教程
如何注册 ECOSteam 开放平台 - 节选自ECOSteam官方文档
- 申请接入流程
- 注册并登录ECO App:
- 进入【我的】,点击右上角设置;
- 点击【账号与安全】进入;
- 点击【开放能力申请】进入介绍页面;
- 点击申请入驻;
- 填写申请资料并提交,回调地址和回调开关配置审核通过后可修改; // 备注: 此处如需上传身份证正反面照片, 可随意上传图片, 不会进行审核
- 等待审核; // 备注: 实际上是自动审核, 申请后立刻可用
- 审核通过后流程
- 审核通过的用户,可回到页面点击【查看身份ID】;
- 输入RSA公钥后,获取身份ID; // 备注: RSA公钥在插件运行后需要填写进在config目录下的rsakey.txt中, 请自行生成RSA密钥对, 建议使用2048位或4096位密钥, 如果你不会生成且不想学习, 可以使用在线生成工具生成, 例如https://www.ssleye.com/ssltool/pass_double.html (若使用此网站, 请设置算法: RSA, 强度: 2048或4096, 密码留空, 安全性我们不能作保证, 请自行判断) 此处请注意: 使用密钥时不要带头尾标识,例如: -----BEGIN PUBLIC KEY----- -----END PUBLIC KEY----- 或 -----BEGIN PRIVATE KEY----- -----END PRIVATE KEY----- 只使用不带换行格式的密钥内容部分。
- 如开启回调通知,则需配置回调地址和获取ECO的回调公钥;
感谢 @lupohan44 为本项目提交的大量代码!
感谢 devgod, 14m0k(QQ群用户) 在开发供应求购订单功能时的巨大帮助!