Skip to content
/ abac Public

ABAC [Action Based Access Control] implementation using Golang

Notifications You must be signed in to change notification settings

raisultan/abac

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Action Based Access Control [ABAC]

Tech Stack

  • Golang
  • Docker

Entities

entities

Routes

entities

Project Structure

/pkg - The Framework

- `/pkg/utils/`, `/pkg/config/`, ...
- No dependencies on `/cmd`
- Can be imported by external programs

/cmd - The Programs

- `/cmd/abac/`, `/cmd/service/`, ...
- Domain specific logic stays close to the main() func

Todo:

  • setup migrations
  • user model implementation
  • CRUD for user model
  • password keeping mech
  • field level validation
  • password hiding
  • check for required fields on each scheme
  • basic JWT auth
  • jwt support for all routes
  • refactor and restructure the whole project
  • refactoring teardown
  • server graceful shutdown
  • basic logging
  • add auth middleware
  • add request body validators
  • add decode interface to all request schemas, so decode and validation will be transferred there
  • add Group and Action entities
  • add migration schemas for Group and Action
  • CRUD for Group entity
  • CRUD for Action entity
  • add extension for jwt token payload schema to handle needed BL
  • extend existing AC to pass new payload schema

About

ABAC [Action Based Access Control] implementation using Golang

Resources

Stars

Watchers

Forks