Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/csznet/tgState
使用Telegram作为存储的文件外链系统,不限制文件大小和格式。
https://github.com/csznet/tgState
file file-sharing file-upload filesystem go golang images imageserver img storage storage-api storage-service telegram telegram-api telegram-bot telegram-bot-api telegrambot vercel
Last synced: about 1 month ago
JSON representation
使用Telegram作为存储的文件外链系统,不限制文件大小和格式。
- Host: GitHub
- URL: https://github.com/csznet/tgState
- Owner: csznet
- License: mit
- Created: 2023-10-02T07:33:11.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-18T01:26:52.000Z (8 months ago)
- Last Synced: 2024-10-12T18:42:14.604Z (2 months ago)
- Topics: file, file-sharing, file-upload, filesystem, go, golang, images, imageserver, img, storage, storage-api, storage-service, telegram, telegram-api, telegram-bot, telegram-bot-api, telegrambot, vercel
- Language: Go
- Homepage: https://www.csz.net
- Size: 113 KB
- Stars: 872
- Watchers: 1
- Forks: 143
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-cloudflare - tgState
README
tgState
==[English](https://github.com/csznet/tgState/blob/main/README_en.md)
一款以Telegram作为储存的文件外链系统
不限制文件大小和格式
可以作为telegram图床,也可以作为telegram网盘使用。
支持web上传文件和telegram直接上传
搭配CLoudFlare使用:https://github.com/csznet/tgState/blob/main/CloudFlare.md
如有疑惑,可以咨询TG @tgstate123
# 演示
https://tgstate.vercel.app / https://tgstate.ikun123.com/
搭建在vercel,资源限制,大于5MB的文件不支持
不限制大小demo(临时) http://tgstate-cdn.ikun123.com/
演示图片:
![tgState](https://tgstate.vercel.app/d/BQACAgUAAx0EcyK3ugACByxlOR-Nfl4esavoO4zdaYIP_k1KYQACDAsAAkf4yFVpf_awaEkS8jAE)
# 参数说明
必填参数
- target
- token可选参数
- pass
- mode
- url
- port## target
目标可为频道、群组、个人
当目标为频道时,需要将Bot拉入频道作为管理员,公开频道并自定义频道Link,target值填写Link,如@xxxx
当目标为群组时,需要将Bot拉入群组,公开群组并自定义群组Link,target值填写Link,如@xxxx
当目标为个人时,则为telegram id(@getmyid_bot获取)
## token
填写你的bot token
## pass
填写访问密码,如不需要,直接填写```none```即可
## mode
- ```p``` 代表网盘模式运行,不限制上传后缀
- ```m``` 在p模式的基础上关闭网页上传,可私聊进行上传(如果target是个人,则只支持指定用户进行私聊上传## url
bot获取FileID的前置域名地址自动补充及api返回完整url的补充
## port
自定义运行端口
# 管理
## 获取FIleID
对bot聊天中的文件引用并回复```get```可以获取FileID,搭建地址+获取的path即可访问资源
如果配置了url参数,会直接返回完整的地址
![image](https://github.com/csznet/tgState/assets/127601663/5b1fd6c0-652c-41de-bb63-e2f20b257022)
# 部署
## 二进制
Linux amd64下载
```
wget https://github.com/csznet/tgState/releases/latest/download/tgState.zip && unzip tgState.zip && rm tgState.zip
```Linux arm64下载
```
wget https://github.com/csznet/tgState/releases/latest/download/tgState_arm64.zip && unzip tgState_arm64.zip && rm tgState_arm64.zip
```Linux 一键脚本
```
bash -c "$(curl -fsSL https://raw.githubusercontent.com/csznet/tgState/main/get.sh)"
```**使用方法**
```
./tgState 参数
```**例子**
```
./tgState -token xxxx -target @xxxx
```**后台运行**
```
nohup ./tgState 参数 &
```## Docker
pull镜像
```
docker pull csznet/tgstate:latest
```启动
```
docker run -d -p 8088:8088 --name tgstate 参数 --net=host csznet/tgstate:latest
```
其中docker的参数需要设置为环境变量开机自启需要加上
```
--restart always
```**例子**
```
docker run -d -p 8088:8088 --name tgstate -e token=token -e target=@target -e mode=p --net=host csznet/tgstate:latest
```## Vercel
不支持大于5mb文件,不支持tg获取文件路径
[点我传送至Vercel配置页面](https://vercel.com/new/clone?repository-url=https%3A%2F%2Fgithub.com%2Fcsznet%2FtgState&env=token&env=target&env=pass&env=mode&env=url&project-name=tgState&repository-name=tgState)
# API说明
POST方法到路径```/api```
表单传输,字段名为image,内容为二进制数据
当设置访问密码时,直接将密码加入url参数pass中,如密码为123:
```
/api?pass=123
```返回示例:
```json
{"code": 1, "message": "/d/xxx","url":"xxx"}
```json格式的`url`默认返回tgState的`url`参数+访问路径,如果只得到了路径则需要自行设置`url`参数
picgo-plugin-web-uploader填写说明:
POST参数名:`image`
JSON路径:`url`
![image](https://github.com/csznet/tgState/assets/127601663/d70e6a42-1f21-4cbb-8ba5-1e9f7d9660a4)