Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qingwave/weave
Golang+Vue3 application starter, Simple but functional.
https://github.com/qingwave/weave
docker element-plus gin go golang jwt kuerbentes postgres rbac redis restful swagger vue vue3
Last synced: 5 days ago
JSON representation
Golang+Vue3 application starter, Simple but functional.
- Host: GitHub
- URL: https://github.com/qingwave/weave
- Owner: qingwave
- License: apache-2.0
- Created: 2019-12-09T00:43:32.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-09-26T18:54:57.000Z (5 months ago)
- Last Synced: 2025-02-08T08:04:52.561Z (12 days ago)
- Topics: docker, element-plus, gin, go, golang, jwt, kuerbentes, postgres, rbac, redis, restful, swagger, vue, vue3
- Language: Go
- Homepage: https://qingwave.github.io/weave/
- Size: 39.7 MB
- Stars: 561
- Watchers: 15
- Forks: 126
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# Weave
[data:image/s3,"s3://crabby-images/dda1f/dda1f3f6b48fb50066eeb75d529ddefb5f4d00e6" alt="workflows"](https://github.com/qingwave/weave/actions?query=workflow%3Aweave)
[data:image/s3,"s3://crabby-images/c4f54/c4f5420aa362ea0265830f0c44eee1956e44e97d" alt="Go Report Card"](https://goreportcard.com/report/github.com/qingwave/weave)
[data:image/s3,"s3://crabby-images/9c134/9c134b41333359c0632b15df67a4fc840acba944" alt="codecov"](https://codecov.io/gh/qingwave/weave)
[data:image/s3,"s3://crabby-images/83728/83728c2a03f768ffd7cd23f4d8ad1c116e626265" alt="GitHub license"](https://github.com/qingwave/weave/blob/master/LICENSE)
---
> English | [中文](README_zh.md)
Weave is a Go + Vue3 application starter, simple but functional, supported by gin, gorm, redis, postgres, vue, element-plus, websocket and much more.
See [Demo](https://qingwave.github.io/weave/).
Login
Home
![]()
![]()
Dashboard
App
![]()
![]()
Web Shell
Web Code Editor
![]()
![]()
## Demo
Demo website: see https://qingwave.github.io/weave/
Run ui with docker(no server and databases)
```bash
docker run -d -p 8080:80 --name weave-frontend qingwave/weave-frontend:mock
```## Features
Server support features:
- Restful api, write by gin
- MVC structure
- Postgres storage, via gorm
- Swagger doc, support by swag
- Structured log, support by logrus
- Prometheus monitor
- PProf debug
- Graceful shutdown
- Authentication, support jwt
- Request rate limit, server level or user ip
- OAuth Login and store hashed password
- Redis cache
- RBAC supported
- Container application management, support docker and kubernetes
- Post managementFrontend support features:
- Vue3 supported
- UI with element-plus
- Build with vite
- Charts integration, support by echarts
- WebShell supported
- Windi CSS
- OAuth Login
- Web code editor, support by codemirror
- MarkDown preview and editorTODOs
- [x] Redis cache
- [x] Request rate limit
- [x] Authentication
- [x] WebSocket
- [x] Trace
- [x] UI
- [x] WebShell
- [ ] Dark theme
- [ ] Mobile UI
## Get started
Before starting, you should already install [golang](https://go.dev/), [docker](https://docs.docker.com/engine/install/) and [nodejs](https://nodejs.org/en/download/) in your develop env.
### Run serverEnv:
- golang (1.18 or later)Install dependencies, postgresql, redis, swag
```bash
make init
```run locally
```bash
make run
```run server in docker
```bash
# build image
make docker-build-server
# run server
make docker-run-server
```> For Windows, you can run script in [Makefile](./Makefile) manually
### Test api
See more api in http://localhost:8080/index
See swagger http://localhost:8080/swagger/index.html#/Register user
```bash
curl -XPOST http://localhost:8080/api/v1/auth/user -d '{"name": "zhang3", "email": "[email protected]","password": "123456"}'
```Login, get jwt token
> Only admin user can access any apis, other user need create RBAC policy
```bash
curl -XPOST http://localhost:8080/api/v1/auth/token -d '{"name": "admin", "password": "123456"}'
```
Response as follows, set token in `Authorization` Header
```json
{
"code": 200,
"msg": "success",
"data": {
"token": "xxx",
"describe": "set token in Authorization Header, [Authorization: Bearer {token}]"
}
}
```Get users
```bash
token=xxx
curl -X 'GET' 'http://localhost:8080/api/v1/users' -H "Authorization: Bearer $token"
```### Run UI
Assume you have installed `Nodejs`, if not, install it by [nvm](https://github.com/nvm-sh/nvm#install--update-script)Run ui with mockjs
```bash
cd web
npm run mock
```If your frontend deploy in the remote, please change `server.host` and `server.https` in [vite.config.js](./web/vite.config.js).
Run ui with command `make ui` or
```bash
cd web
npm i
npm run dev
```Default admin user `admin/123456`
or demo user `demo/123456`> Only admin user can access all api, other user must config RBAC at first
Explore in http://127.0.0.1:8081
run frontend in docker
```bash
# build image
make docker-build-ui
# run frontend
make docker-run-ui
```More ui in [img](./document/img/)
- Login page
data:image/s3,"s3://crabby-images/abf2d/abf2d15341b87b633529b8fca47aac73526f3c88" alt="login"- Dashboard page
data:image/s3,"s3://crabby-images/0408f/0408f8dbdde0ec34e9f8ee9dd9b11c11912d92f0" alt="dashboard"- App page
data:image/s3,"s3://crabby-images/6111a/6111aa5e49d062e12ee36fa02cd7d5bdf81a27c6" alt="app"- Webshell page
data:image/s3,"s3://crabby-images/b1391/b1391d7d8017205a7e9527ef78512908fa15467a" alt="webshell"- Blog list
data:image/s3,"s3://crabby-images/21468/21468f56458bdbc9597137fadb37abbc30e2d337" alt="Blog"- Article
data:image/s3,"s3://crabby-images/d120e/d120e8b094458eee6d992f5633f499a0f4de3ac8" alt="article"### Documents
- [Contributing](./CONTRIBUTING.md), contributing details
- [Config](./config/app.yaml), your can enable docker/kubernetes in config
- [OAuth](./document/oauth.md)
- [RBAC](./document/authentication.md)