https://github.com/infraboard/keyauth
keyauth是一个微服务权限治理中心, 提供用户认证与授权管理
https://github.com/infraboard/keyauth
auth-provider authentication authorization microservice oauth2 rbac-management ucenter user-management
Last synced: 5 days ago
JSON representation
keyauth是一个微服务权限治理中心, 提供用户认证与授权管理
- Host: GitHub
- URL: https://github.com/infraboard/keyauth
- Owner: infraboard
- License: mit
- Created: 2019-11-09T01:45:30.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-06-01T20:14:20.000Z (over 2 years ago)
- Last Synced: 2024-06-18T15:31:14.778Z (over 1 year ago)
- Topics: auth-provider, authentication, authorization, microservice, oauth2, rbac-management, ucenter, user-management
- Language: Go
- Homepage:
- Size: 2.85 MB
- Stars: 90
- Watchers: 9
- Forks: 28
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# keyauth
[](https://goreportcard.com/report/github.com/infraboard/keyauth)

keyauth是一个微服务权限治理中心, 提供用户认证与授权管理.
demo访问地址: [Demo](http://keyauth.nbtuan.vip/) 用户: admin, 密码: 12345678mM@1
## 功能
+ 登录安全
+ 用户认证: Password/LDAP/AccessToken/Oauth2.0其他模式
+ 单点登录: 同一账号同一时间只能在一个客户端登录
+ 密码安全: 密码强度校验, 密码过期提醒, 密码重复限制
+ IP黑白名: 用户登录IP黑白名单限制
+ 异常登录: 失败重试检测, 异地登录检测, 30天未登录检测
+ 智能多因子认证: 异常登录时 支持邮件/短信方式对用户进行二次身份验证
+ 登录日志: 记录用户登录时间, 地点, IP, 登录端 等
+ 权限管理:
+ 部门管理: 部门人员和部门工作空间管理
+ 权限模型: 基于工作空间的【RBAC】授权
+ 角色管理: 基于标签的权限条目匹配, 灵活编辑角色
+ 服务目录: 服务将功能注册到keyauth, keyauth基于这些服务功能 提供RBAC鉴权机制
## SDK使用
注意SDK权限很大, 仅供内部服务调用, 如果对外,请走HTTP API
```go
package main
import (
"context"
"fmt"
"github.com/infraboard/keyauth/apps/domain"
"github.com/infraboard/keyauth/apps/user"
"github.com/infraboard/keyauth/client"
)
func main() {
conf := client.NewDefaultConfig()
// 提前注册一个服务, 获取服务的client_id和client_secret
conf.SetClientCredentials("pz3HiVQA3indzSHzFKtLHaJW", "vDvlAtqN3rS9CZcHugXp6QBuk28zRjud")
c, err := client.NewClient(conf)
if err != nil {
panic(err)
}
// 查询用户信息, 查询admin domain里面的用户
req := user.NewQueryAccountRequest()
req.Domain = domain.AdminDomainName
eps, err := c.User().QueryAccount(context.Background(), req)
fmt.Println(eps, err)
}
```
## 快速开发
1. 依赖环境搭建:
+ [MongoDB数据库安装](./docs/mongodb/install.md) (必须)
+ [OpenLDAP安装](./docs/ldap/install.md) (开启LDAP认证时需要安装)
+ [消息总线](./docs/bus/install.md) (开启操作审计时需要安装)
+ [安装protobuf](./docs/protobuf/install.md)(keyauth开发者)
2. 快速运行
```sh
# 安装依赖
make install
# 配置
mv /etc/keyauth_sample.toml /etc/keyauth.toml
vim /etc/keyauth.toml
# 初始化服务
make init
# 启动服务
make run
```