# README
go-saas
headless go framework for saas(multi-tenancy).
go-saas
targets to provide saas solution for go
this project suits for simple (web) project, which is also called monolithic.
if you are finding complete solution which is microservice compatible, please refer to go-saas-kit
Overview
Feature
-
Different database architecture
- Single-tenancy: Each database stores data from only one tenant.
- Multi-tenancy: Each database stores data from multiple separate tenants (with mechanisms to protect data privacy).
-
Hybrid tenancy models are also available.
-
Implement your own resolver to achieve style like sharding
-
Support multiple web framework
-
Supported orm with data filter, which means all underlying database
-
Customizable tenant resolver
- Query String
- Form parameters
- Header
- Cookie
- Domain format
-
Seed and Migration
- Seed/Migrate tenant database after creation or upgrade to new version
-
Integration with gateway
Install
go get github.com/go-saas/saas
Design
graph TD
A(InComming Request) -->|cookie,domain,form,header,query...|B(TenantResolver)
B --> C(Tenant Context) --> D(ConnectionString Resolver)
D --> E(Tenant 1) --> J(Data Filter) --> H(Shared Database)
D --> F(Tenant 2) --> J
D --> G(Tenant 3) --> I(Tenant 3 Database)
Sample Project
- example-gorm combination of
go-saas
,gin
,gorm(sqlite/mysql)
- example-ent combination of
go-saas
,gin
,ent(sqlite)
- go-saas-kit Microservice architecture starter kit for golang sass project
Documentation
Refer to wiki
References
https://docs.microsoft.com/en-us/azure/azure-sql/database/saas-tenancy-app-design-patterns
# Packages
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
# Functions
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
NewCache creates a new thread safe LRU cache whose capacity is the default size (128).
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
NewMultiTenancyConnStrResolver from tenant.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
WithCapacity is an option to set cache capacity.
WithDatabaseStyle database style, support Single/PerTenant/Multi.
WithEnabled enable status.
# Variables
No description provided by the author
# Structs
No description provided by the author
Cache is used a LRU (Least recently used) cache replacement policy.
No description provided by the author
ContextContrib resolve from current context.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
TenantNormalizerContrib normalize tenant id or name into tenant id.
No description provided by the author
No description provided by the author
# Interfaces
No description provided by the author
ConnStrGenerator generate connection string for tenant.
No description provided by the author
TenantConfigProvider resolve tenant config from current context.
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
# Type aliases
No description provided by the author
No description provided by the author
No description provided by the author
Option is an option for LRU cache.
No description provided by the author