-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit b5caac4
Showing
512 changed files
with
195,005 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
--- | ||
upload: false | ||
delete: false | ||
noaccess: false | ||
users: | ||
- username: "lkong" | ||
delete: true | ||
upload: true | ||
noaccess: false | ||
accessTables: | ||
- regex: block.file | ||
allow: false | ||
- regex: visual.file | ||
allow: true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
# Compiled Object files, Static and Dynamic libs (Shared Objects) | ||
*.o | ||
*.a | ||
*.so | ||
|
||
# Folders | ||
_obj | ||
_test | ||
|
||
# Vim-related files | ||
[._]*.s[a-w][a-z] | ||
[._]s[a-w][a-z] | ||
.*~ | ||
*~ | ||
|
||
logs/** | ||
|
||
# Architecture specific extensions/prefixes | ||
*.[568vq] | ||
[568vq].out | ||
|
||
*.cgo1.go | ||
*.cgo2.c | ||
_cgo_defun.c | ||
_cgo_gotypes.go | ||
_cgo_export.* | ||
|
||
_testmain.go | ||
|
||
*.exe | ||
*.test | ||
*.prof | ||
|
||
dist/ | ||
bindata_assetfs.go | ||
grapehttp | ||
fctl | ||
|
||
# other files | ||
.ghs.yaml | ||
dev-config.yaml |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
project_name: grapehttp | ||
release: | ||
github: | ||
owner: lexkong | ||
name: grapehttp | ||
brew: | ||
install: bin.install "grapehttp" | ||
builds: | ||
- goos: | ||
- linux | ||
- darwin | ||
- windows | ||
goarch: | ||
- amd64 | ||
- "386" | ||
goarm: | ||
- "6" | ||
main: . | ||
ldflags: -s -w -X main.VERSION={{.Version}} | ||
flags: -tags bindata | ||
binary: grapehttp | ||
archive: | ||
format: tar.gz | ||
name_template: '{{ .Binary }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}{{ if .Arm }}v{{ | ||
.Arm }}{{ end }}' | ||
files: | ||
- licence* | ||
- LICENCE* | ||
- license* | ||
- LICENSE* | ||
- readme* | ||
- README* | ||
- changelog* | ||
- CHANGELOG* | ||
- .ghs.yml | ||
snapshot: | ||
name_template: SNAPSHOT-{{ .Commit }} | ||
checksum: | ||
name_template: '{{ .ProjectName }}_{{ .Version }}_checksums.txt' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
The MIT License (MIT) | ||
|
||
Copyright (c) 2016 lingfei kong | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
SHELL := /bin/bash | ||
VERSION = 1.0.0 | ||
CURDIR = $(shell pwd) | ||
BASEDIR = ${CURDIR} | ||
|
||
# build with verison infos | ||
versionDir = "grapehttp/pkg/vinfo" | ||
gitTag = $(shell if [ "`git describe --tags --abbrev=0`" != "" ];then git describe --tags --abbrev=0; else git log --pretty=format:'%h' -n 1; fi) | ||
buildDate = $(shell TZ=Asia/Shanghai date +%FT%T%z) | ||
gitCommit = $(shell git log --pretty=format:'%H' -n 1) | ||
gitTreeState = $(shell if git status|grep -q 'clean';then echo clean; else echo dirty; fi) | ||
LDFLAGS="-w -X ${versionDir}.gitTag=${gitTag} -X ${versionDir}.buildDate=${buildDate} -X ${versionDir}.gitCommit=${gitCommit} -X ${versionDir}.gitTreeState=${gitTreeState}" | ||
|
||
all: gotool fctl server | ||
|
||
server: | ||
@go build -v -ldflags ${LDFLAGS} | ||
|
||
fctl: | ||
@make -C ${BASEDIR}/client | ||
@echo binary file is: ${BASEDIR}/fctl | ||
|
||
gotool: | ||
@-gofmt -w . | ||
@-go tool vet . |& grep -v vendor | ||
|
||
clean: | ||
rm -f grapehttp | ||
|
||
.PHONY: gotool clean fctl |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,203 @@ | ||
# grapehttp | ||
|
||
超级好用的HTTP文件服务器,可以通过web端和命令行来访问和操作文件服务器。其他特性有文件夹访问权限控制,登陆授权等。 | ||
|
||
**需求背景** | ||
|
||
1. 项目组没有一个公用的文件服务器,相互传文件不方便,不同电脑之间转移文件也不方便(密码一直在变) | ||
2. 因为公司网络原因,上传文件到内网,需要通过rz, sz命令,这种方式传输速度慢,有一定几率会传输失败 | ||
|
||
## Screenshots | ||
**Grapehttp Web UI** | ||
data:image/s3,"s3://crabby-images/94240/94240d2976fe11ad72e85c566bba608d5ede80e3" alt="WebUI" | ||
|
||
**fctl File Server Commands** | ||
data:image/s3,"s3://crabby-images/3f238/3f23816b2619a592fbf3c37a7144d8d1c435deff" alt="fctl file operating commands" | ||
|
||
**fctl User Control Commands** | ||
data:image/s3,"s3://crabby-images/7a1b6/7a1b674babb7d186a752c8260b7ace9b4136943e" alt="fctl user operating commands" | ||
|
||
## Features | ||
|
||
+ 安装只需要一个单独的二进制文件,不需要其它依赖 | ||
+ 不同的文件展示不同的icon | ||
+ 支持隐藏或者显示文件 | ||
+ 上传文件支持(安全起见,需要指定--upload参数) | ||
+ README.md 文件预览 | ||
+ HTTP Basic Auth | ||
+ 支持文件夹压缩成zip后下载 | ||
+ 线下下载支持 | ||
+ 全局文件搜索 | ||
+ Hidden work download and qrcode in small screen | ||
+ 可选择不同的界面风格 | ||
+ 可以通过nginx代理 | ||
+ 文件夹权限控制(通过.ghs.yml文件) | ||
+ 可以自定义Web界面标题 | ||
+ 支持配置文件 | ||
+ 快速复制下载链接 | ||
+ 显示文件夹大小 | ||
+ 客户端工具fctl支持子命令自动补全 | ||
|
||
## 安装 | ||
|
||
### 安装前准备 | ||
|
||
**Binaries** can be downloaded from [this repo releases](https://github.com/lexkong/grapehttp/releases/) | ||
|
||
**修改grapehttp的配置** | ||
|
||
grapehttp的配置文件为:httpconfig.yaml | ||
|
||
当simpleauth=false时,需要初始化tb_http_user表(假定已经下载或编译好了grapehttp) | ||
``` | ||
./grapehttp -d -c httpconfig.yaml | ||
``` | ||
初始化管理员用户名和密码为:admin:admin | ||
这里主要修改rbac的对应项,rbac是用来对连接http server进行用户名和密码校验。 | ||
|
||
|
||
**修改fctl的配置:** | ||
``` | ||
mkdir ~/.grape/ | ||
cp client/config.yaml ~/.grape/ | ||
``` | ||
|
||
### 二进制安装 | ||
|
||
1. 下载二进制文件:fctl 和 grapehttp | ||
|
||
2. 启动grapehttp | ||
``` | ||
./grapehttp -c httpconfig.yaml | ||
``` | ||
|
||
3. 执行`./fctl -h`获取客户端fctl工具使用帮助 | ||
|
||
|
||
### 源码安装 | ||
|
||
``` | ||
git clone https://github.com/lexkong/grapehttp.git | ||
make | ||
./admin.sh start | ||
./fctl ls / | ||
``` | ||
|
||
### admin.sh操作 | ||
|
||
+ 启动服务:admin.sh start | ||
+ 停止服务:admin.sh stop | ||
+ 重启服务:admin.sh restart | ||
+ 查看服务状态:admin.sh status | ||
|
||
## fctl命令行工具Usage | ||
|
||
### HTTP Server相关操作命令 | ||
|
||
``` | ||
ls List directory contents | ||
mkdir Create specified directory | ||
mv Move (rename) files | ||
cp Copy files and directories | ||
rm Remove files or directories | ||
upload Upload files to remote http server | ||
download Download files from remote http server | ||
``` | ||
|
||
### HTTP Server用户管理相关命令 | ||
|
||
``` | ||
add Create a new user | ||
del Delete users | ||
modify Modify user's email, password, nickname and remark | ||
search Search users with fuzzy match condition | ||
get Get user informations | ||
list List existing users with mysql limit and offset | ||
enable Enable users | ||
disable Disable users | ||
``` | ||
|
||
### 其它命令 | ||
|
||
``` | ||
finfo Get http server basic information | ||
help Help about any command | ||
version Print the client and server version information | ||
``` | ||
|
||
**更详细请查看:`./fctl -h` or `./fctl SUBCOMMAND -h`** | ||
|
||
## 高级用法 | ||
|
||
通过在目录下创建`.ghs.yml`来增加该目录的权限控制规则, 例如: | ||
|
||
```yaml | ||
--- | ||
upload: false | ||
delete: false | ||
noaccess: false | ||
users: | ||
- username: "lkong" | ||
delete: true | ||
upload: true | ||
``` | ||
在这个例子中,只有登录用户名为lkong的用户,才有权限在目录下执行删除和上传的操作。 | ||
通过在`.ghs.yml`文件中添加以下行,来控制哪些文件可见,哪些文件不可见。 | ||
|
||
```yaml | ||
accessTables: | ||
- regex: block.file | ||
allow: false | ||
- regex: visual.file | ||
allow: true | ||
``` | ||
|
||
### ipa plist proxy | ||
如果服务器激活了https,可以这么用: | ||
|
||
``` | ||
./gohttpserver --plistproxy=https://someproxyhost.com/ | ||
``` | ||
测试是否工作: | ||
```sh | ||
$ http POST https://proxyhost.com/plist < app.plist | ||
{ | ||
"key": "18f99211" | ||
} | ||
$ http GET https://proxyhost.com/plist/18f99211 | ||
# show the app.plist content | ||
``` | ||
|
||
## fctl子命令自动补全 | ||
|
||
**暂时** | ||
``` | ||
source <(fctl completion bash) | ||
``` | ||
|
||
**永久** | ||
``` | ||
fctl completion bash > ~/.grape/completion.bash.inc | ||
echo 'source $HOME/.grape/completion.bash.inc' >> $HOME/.bashrc | ||
``` | ||
|
||
## 用`curl`命令上传文件 | ||
|
||
``` | ||
curl -F [email protected] localhost:6664/somedir | ||
``` | ||
|
||
## 如何构建单个二进制文件 | ||
``` | ||
go get github.com/goreleaser/goreleaser | ||
go get github.com/jteeuwen/go-bindata/... | ||
go get github.com/elazarl/go-bindata-assetfs/... | ||
go-bindata-assetfs -tags bindata res/... | ||
go build -tags bindata | ||
goreleaser | ||
``` |
Oops, something went wrong.