一个简单、安全的 web3 脚本库
名称 | 交互类型 | 成本 | 生态 | 备注 | 进度 |
---|---|---|---|---|---|
avail 💩 | 铸造 NFT | 低 | polkadot | 先领水 | 已空投,没刷到 |
eclipse 👌 | 铸造、转账、兑换、跨链 | 低 | SOL | 不要把水领完! | |
lava 🙉 | rpc 节点调用 | 低 | Cosmos | 签名的数据由 lava 后台指定,存在安全风险 | 官方开始封 ip,无法正常刷 |
frame |
智能合约交互 | 低 | 需要领水 Sepolia、测试网 | 据说项目已经失败 | |
sollong 💩 | 邀请、签到 | 低 | SOL | 钱包需要有 0.1SOL ,上线了滑块验证码,脚本失效 |
已空投,低保 150,刷的积分被清零 |
grass 🙉 | 挖矿 | 中 | 按公网 ip 计算,云服务器 ip 无积分 | 4.9 第三期挖矿结束 | |
spepe 💩 | 登记钱包地址 | 低 | SOL | 脚本失效,官网加了人机检查 | 未按计划发币 |
soll 💩 | 登记钱包地址 | 低 | SOL | 募集到了一些 SOL,可能有空投(疑似 spepe 同一项目方) | 未按计划发币 |
当前只支持 Linux
和 Mac
,如果想在 windows 上使用,可以使用 WSL
。
- 安装
bun
(nodejs 运行时),已经有 nodejs 环境的可以使用npm i -g bun
安装,否则使用curl -fsSL https://bun.sh/install | bash
下载安装 - 安装依赖
bun install
,当前只依赖了,依赖项说明见下方依赖项说明ethers
,为降低安全风险不建议再使用其他依赖 - 每次依赖更新请先使用
bun install
安装依赖
如不使用 bun,也可以把 ts 文件中的代码转为 js 代码使用
交互说明
获取 lava rpc id 可以使用 bun run lava/util.ts
脚本获得,建议在本地生成,再更新到配置文件中,这里的助记词一定要记录好,否则找不回钱包
function main() {
// 生成 rpc id,日志中的助记词需要记录下来,仅用于生成 rpc id
generateRPCs(10);
}
使用 bun run lava/util.ts
查询积分,按需使用助记词或私钥查询,因为登录需要钱包签名,所以需要用到助记词或私钥。
function main() {
// 通过助记词查询积分信息,比上面的方法多调一个接口
queryMeByMnemonic('word1 word2 word3 ...', 10);
// 通过私钥查询积分信息,比上面的方法多调一个接口
// queryMeByKeys(['0x...', '0x...']);
}
lava net 的积分是通过调用 rpc 节点获得,使用 lava/rpc.ts
脚本,单个 rpc 节点会串行调用,脚本中分别会通过查询钱包资产
和代币资产
来刷积分
- 在 lava 获取 rpc 节点
- 将获取到的 rpc 节点配置到
config.toml
中 - 使用
nohup bun run lava/rpc.ts >> logs/lava.log 2>&1 &
后台运行,如果是在服务器上运行,请在断开远程连接后再登录确定进程是否正常
- 登录环节中会用到私钥进行签名,签名的内容由 lava 后台返回,存在安全风险!避免使用存在大额资金的钱包登录
sollong 可使用邀请码 ea6m5z
,当前脚本使用了兼容 phantom
钱包的算法,可以直接把助记词导入 phantom
使用
使用步骤
- 将可用的、或者需要刷邀请积分的邀请码配置到
config.toml
中的inviteCodes
- 将需要刷签到的钱包助记词配置到
config.toml
中的mnemonic
- 完成配置后执行
nohup bun run sollong/index.ts >> logs/sollong.log 2>&1 &
即可后台运行
交互说明
本地生成助记词(最好是新的,避免安全风险)后配置到 config.toml
中,配置通过助记词派生的钱包数量 wallet.count
即需要刷的钱包数量。
只刷邀请积分可以不用提供助记词、私钥
把生成的邀请码,添加到配置文件 config.toml
中即可,会跟上面的签到一起执行
邀请码邀请的帐号每天都签到,一个邀请码会对应一个 HD 钱包助记词存储到 sollong/data.json
文件中
执行 bun run sollong/util.ts
即可
solana 生态的 L2,测试网激励
先将本地生成的助记词(优先使用新的)配置到配置文件中
交互说明
跨链和铸造代币的交互需要的 SOL 相对多一些,如果没有 sepolia 的水,可以不用挂这两个交互任务
从 sepolia 跨链到 eclipse testnet,需要从 sepolia 领水,很多水龙头都限制了只给主网有 ETH 资产的地址
执行脚本 nohup bun run eclipse/bridge.ts >> logs/eclipse-bridge.log 2>&1 &
- 创建代币
- 铸造代币
- 发送代币
执行脚本 nohup bun run eclipse/token.ts >> logs/eclipse-token.log 2>&1 &
- 领 sol 水 (最好先注释掉其他两个,先把 sol 的领了)
- 领 USDC, BTC, ETH 水
- swap
nohup bun run eclipse/invariant.ts >> logs/eclipse-invariant.log 2>&1 &
polkadot 生态,测试网任务,完成任务后铸造 NFT
先将本地生成的助记词和水龙头的助记词配置到配置文件中
交互说明
执行 bun run avail/transfer.ts
脚本分发 AVL
用于 NFT 铸造,单次 mint 需要准备 0.02 AVL
,脚本会根据水龙头的资产进行分发,也可以修改脚本中的值来跳转分发的钱包数
执行 bun run avail/nft.ts
脚本铸造 NFT,每次铸造前会先检查资产是否 >= 0.02
,如果小于则跳过
直接用 sol 钱包登记即可,邀请码可以邀请 20 个再获得 20 份奖励。
执行时,会分别从 spepe/config.toml
和 spepe/data.json
中获取邀请码,并让每个邀请码邀请 20 次。spepe/config.toml
文件中至少要配置一个可用的邀请码
由于不确定邀请码总共只能邀请 20 次,先存到文件中
- 执行
nohup bun run spepe/index.ts >> logs/spepe.log 2>&1 &
- 执行完成后会把新的助记词和邀请码保存到
spepe/data.json
文件中
登记钱包地址即可,站点代码和 spepe
差不多,估计是同一个项目方。募集的钱包地址里面已经有了500+ SOL,且站点还没有加人机验证,可以先刷。
- 先在 soll.cc 登记一个钱包,然后把邀请码复制到
soll/config.toml
中 - 执行
bun run soll/index.ts
,每个邀请码会邀请 5~15 个钱包,并将最终的用到的助记词和最新可用的邀请码放到soll/data.json
中
每次执行登记的地址数量为,soll/config.toml
配置的邀请码数 * 随机邀请数(5~15),如 soll/data.json
中存在邀请码,则以这个为准。
单个 ip 不建议过多,否则容易被女巫
在本地获取到 userId
后配置到配置文件 config.toml
中,执行 nohup bun run grass/index.ts >> logs/grass.log 2>&1 &
即可
从插件源码中获悉,当前挖矿的逻辑基本上为保持 WebSocket
在线即可。
核心挖矿逻辑为,将通过 WebSocket
分发指定报文信息中的 base64
字符串转为 Blob
(二进制)调用指定 url
请求。(当前未见分发过该类型报文)
依赖项 | 用途 | 备注 |
---|---|---|
ethers | eth 生态交互支持 | 签名、智能合约交互、交易 |
bip39 | 助记词生成 seed | 支持 HD 钱包 |
micro-ed25519-hdkey | HD 钱包派生 | 支持 HD 钱包 |
tweetnacl | solana 签名 | |
@solana/web3.js | sol 生态支持 | |
@solana/spl-token-metadata | sol 代币创建 | |
@solana/spl-token | sol 代币交互 | |
@metaplex-foundation/js | sol NFT 交互 | |
@project-serum/anchor | sol 智能合约交互 | |
@polkadot/api | polkadot 生态链上交互 | |
@polkadot/keyring | polkadot 生态账户钱包处理 | |
@polkadot/util-crypto | polkadot 密码学相关 | |
bn.js | 科学计数 |