jumpserver/apps/common
fit2bot f548b4bd2b
feat: serializer 添加默认值,前端可以调用 (#5666)
perf: 优化默认值

Co-authored-by: ibuler <ibuler@qq.com>
2021-03-02 19:18:25 +08:00
..
auth
const refactor tree (重构&优化资产树/用户授权树加载速度) (#5548) (#5549) 2021-02-05 13:29:29 +08:00
db fix: 修复授权树一些问题 2021-03-01 18:09:41 +08:00
drf feat: serializer 添加默认值,前端可以调用 (#5666) 2021-03-02 19:18:25 +08:00
fields feat: 抽象View Mapping Serializer架构设计; 重构工单View、Serializer模块 (#5371) 2021-01-02 07:25:23 +08:00
migrations
mixins feat: serializer 添加默认值,前端可以调用 (#5666) 2021-03-02 19:18:25 +08:00
templatetags
urls
utils perf: 优化系统用户生成密码的复杂度 (#5648) 2021-03-01 18:40:07 +08:00
README.md 1.5.7 Merge to dev (#3766) 2020-03-12 16:24:38 +08:00
__init__.py
api.py fix: 修改common resource api的权限,否则auditor无法使用 2020-06-05 14:43:40 +08:00
apps.py
cache.py refactor: 调整组织统计数据缓存的更新策略为懒更新模式 2021-02-23 17:48:14 +08:00
compat.py
decorator.py
exceptions.py fix: 批量删除管理用户报错信息太丑 2020-12-17 14:47:37 +08:00
http.py fix(perms): 用户添加到用户组报错 2020-09-27 20:53:34 +08:00
local.py perf(settings): 优化settings配置 (#5515) 2021-01-26 17:54:12 +08:00
permissions.py perf(orgs): 默认组织改为实体组织,并支持全局组织 (#5617) 2021-03-02 14:57:48 +08:00
signals.py
signals_handlers.py perf(settings): 优化settings配置 (#5515) 2021-01-26 17:54:12 +08:00
struct.py 1.5.7 Merge to dev (#3766) 2020-03-12 16:24:38 +08:00
tasks.py feat: 添加缓存模块,添加组织资源统计 (#5407) 2021-01-17 12:08:21 +08:00
tests.py
thread_pools.py perf(assets): 优化节点树 2020-09-21 10:23:09 +08:00
tree.py
validators.py fix(django3): 修复django3兼容问题 2020-11-20 15:25:37 +08:00

README.md

Common app

Common app provide common view, function or others.

Common app shouldn't rely on other apps, because It may lead to cycle import.

If your want to implement some function or class, you should think whether other app use or not. If yes, You should make in common.

If the ability more relate to your app tightness, It's mean your app provide this ability, not common, You should write it on your app utils.

Celery usage

JumpServer use celery to run task async. Using redis as the broker, so you should run a redis instance

Run redis

$ yum -y install redis 

or

$ docker run -name jumpserver-redis -d -p 6379:6379 redis redis-server

Write tasks in app_name/tasks.py

ops/tasks.py

from __future__ import absolute_import

import time
from celery import shared_task
from common import celery_app


@shared_task
def longtime_add(x, y):
    print 'long time task begins'
    # sleep 5 seconds
    time.sleep(5)
    print 'long time task finished'
    return x + y
    

@celery_app.task(name='hello-world')
def hello():
    print 'hello world!'
  

Run celery in development

$ cd apps
$ celery -A common worker -l info 

Test using task

$ ./manage.py shell
>>> from ops.tasks import longtime_add
>>> res = longtime_add.delay(1, 2)
>>> res.get()