Metadata-Version: 2.1
Name: django-multi-tenancy
Version: 0.1.3
Summary: Django multi tenant implementation
Home-page: https://github.com/AnsGoo/djangoMultiTenant
Author: ansgoo
Author-email: haiven_123@163.com
License: MIT Licence
Keywords: python,django,mult-tenant
Platform: any
Classifier: Development Status :: 5 - Production/Stable
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: Unix
Classifier: Operating System :: POSIX :: Linux
Classifier: Environment :: Console
Classifier: Environment :: MacOS X
Description-Content-Type: text/markdown
License-File: LICENSE

DjangoMultiTenant
=================

django
多租户方案实现方案，本插件的是在数据库层对租户数据进行了隔离，保证每个租户只能访问自己的数据库信息，完整兼容django所有功能

安装
----

.. code:: shell

    pip install django-multi-tenancy

兼容性
------

-  django >= 3.2

其他django版本未测试，不保证兼容性

配置
----

.. code:: python


    INSTALLED_APPS = [
        'multi_tenant.tenant',
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        ...
        'multi_tenant.proxy',
        #  rest_framework 需要加载rest app
        'multi_tenant.rest'
    ]

    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'corsheaders.middleware.CorsMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        # 需要注释调官方自带的AuthenticationMiddleware，采用插件的MultTenantAuthenticationMiddleware
        # 'django.contrib.auth.middleware.AuthenticationMiddleware',
        'multi_tenant.tenant.middleware.authentication.MultTenantAuthenticationMiddleware',
        'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]

    # AUTH_USER_MODEL 全局用户模型,必须指定
    AUTH_USER_MODEL = 'tenant.GlobalUser'

    # 租户用户模型,不指定默认为：'auth.User'
    AUTH_TENANT_USER_MODEL = 'info.User'

    # 租户模型,不指定默认为：'tenant.Tenant'
    DEFAULT_TENANT_MODEL = 'tenant.Tenant'

    ## 数据库映射，这里只需要定义共用的app
    DATABASE_APPS_MAPPING = {
        'tenant': 'default',
        'admin': 'default',
        'sessions': 'default'
    }

    ## 数据库映射路由
    DATABASE_ROUTERS = ['multi_tenant.tenant.utils.db.MultTenantDBRouter']

主要模块说明以及使用
--------------------

数据库模块
~~~~~~~~~~

1. 默认\ ``default``\ 数据库为主数据库,只保存公共模块数据，租户数据库可以动态创建，创建一个租户，会自动在数据库中创建了一个对应租户的数据库，所有租户的数据库结构相同

2. 可以在\ ``DATABASE_APPS_MAPPING``\ 中指定某个\ ``app``\ 属于公共\ ``app``,还是租户\ ``app``,公共\ ``app``\ 默认数据库链接为\ ``default``

``multi_tenant.tenant`` 多租户模块
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

1. ``Tenant``\ 为租户模型，当然你可以继承\ ``AbstractTenant``\ 来自定义自己的租户模块，并在\ ``settings``\ 中指定\ ``DEFAULT_TENANT_MODEL``\ 常量来指定租户模型

2. ``GlobalUser``
   为全局用户，不分数据哪个租户，这里用\ ``GlobalUser``\ 替代了\ ``django.contrib.auth.models.User``\ 模块，因此\ ``django.contrib.auth.get_user_model``
   获取的是\ ``GlobalUser``\ 对象，相应的\ ``request.user``\ 也是\ ``GlobalUser``\ 对象，用户可以被加入租户，也可以选择不加入租户，加入租户的用户只能访问相应租户数据，不加入租户的用户如果是超级管理员可以访问\ ``全局用户``\ 和\ ``租户信息``

3. 租户用户表默认采用\ ``django.contrib.auth.models.User``,当然你可以选择继承\ ``django.contrib.auth.models.AbstractUser``\ 来自定义自己的租户用户模块，并在settings中指定\ ``AUTH_TENANT_USER_MODEL``\ 常量来指定租户用户，用户可以在租户层面完整的使用\ ``django.contrib.auth``\ 所有功能，包括\ ``User``\ 、\ ``Group``\ 、\ ``Permission``\ 、\ ``Admin``

4. 可以登录Admin
   后台创建租户，也可以使用\ ``createtenant``\ 命令行来创建租户

``multi_tenant.proxy`` 代理模块
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

``ProxyContentType``\ contentType代理，因为在多租户模型中，主数据库和租户数据库数据模型不一样，在不断的迭代更新中，新的租户和老的租户模型\ ``ContentType``\ 数据信息也不一样，django默认自带的\ ``ContentType``\ 模型默认自带缓存，\ ``ProxyContentType``\ 模型无缓存，每次的数据访问都是直接访问数据库，这样避免了\ ``ContentType``\ 信息不一致导致的异常

``multi_tenant.rest`` rest\_framework适配模块
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

1. 对\ ``rest_framework``\ 进行了适配,保证租户只能访问自己的租户的数据
2. 提供了一个\ ``IsTanenatUser``\ 权限类，判断是不是租户用户
3. 适配了\ ``rest_framework``\ 的内置权限\ ``IsAdminUser``\ 、\ ``DjangoModelPermissions``\ 、\ ``DjangoModelPermissionsOrAnonReadOnly``\ 、\ ``DjangoObjectPermissions``

``migrate`` 模块
~~~~~~~~~~~~~~~~

1. 迁移租户数据库，请给\ ``migrate`` 指定\ ``--database``\ 参数值,
   ``--database``
2. 也可以使用‘multimigrate’,必须指定\ ``--database``\ 参数值，或者直接使用\ ``--all``,来迁移所有租户表结构

支持的数据库
------------

适配了支持\ ``django``\ 所有支持的数据库（\ ``SQLite3``\ 、\ ``MySQL``\ 、\ ``Posgres``\ 、\ ``Oracle``\ ）

例子
----

可以参考\ ``examples``\ 的使用

