The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
hxndg

一个简单的 KMS 实现

  •  
  •   hxndg · Apr 6, 2022 · 2677 views
    This topic created in 1500 days ago, the information mentioned may be changed or developed.

    使用 GO 写了一个简单的秘钥管理系统,现在支持的功能

    • 秘钥管理分为三层,rootkey ==> key encryption key ===>access key 。root key 使用服务端证书 hkdf 派生算出来。
    • 每个 access key 按照 namespace & name 做索引。区分 environment (还没限制 environment 必须是 test/staging/production ,现在可以随便写)
    • 使用 grpc 的 tls 双向认证做权限控制,每张 CA 签发出来的证书是一个用户,每个用户证书里面的 subject 需要有不同的 appkey 内容。用户创建 ak 后可以授权给其它用户读取或者更新

    实现上:

    • 使用 postgresql 做数据持久化
    • 使用 grpc 的双向 tls 做认证

    目前功能还比较简单,只有创建 /读取 /授权等功能。还没加入 KEK 轮转,AK 自动生成等功能。等待后期增强。

    有什么建议可以直接提。谢谢

    github 链接: https://github.com/hxndg/qkms

    yongchiu
        1
    yongchiu  
       Apr 6, 2022
    不错,今天正好在弄 KMS
    hxndg
        2
    hxndg  
    OP
       Apr 6, 2022 via Android
    @yongchiu 有啥问题或者需求可以直接提,我正好想把这个做的稍微好用点。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5590 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 08:43 · PVG 16:43 · LAX 01:43 · JFK 04:43
    ♥ Do have faith in what you're doing.