jumpserver/apps/common
ibuler 2cd092af42 [Update] 修改资产创建格式 2019-06-19 19:25:21 +08:00
..
fields [Feature] 添加功能 RemoteApp (#2706) 2019-05-20 19:39:53 +08:00
migrations [Update] 修改迁移 2019-03-04 15:38:59 +08:00
parsers [Update] 解决csv导入导出的问题 2019-05-31 18:20:24 +08:00
renders [Update] 解决csv导入导出的问题 2019-05-31 18:20:24 +08:00
templatetags [Update] 优化 License (#2420) 2019-02-21 18:49:40 +08:00
urls Dev csv (#2640) 2019-05-21 16:24:01 +08:00
utils Password message (#2702) 2019-05-20 12:30:55 +08:00
README.md Finish permissin detail asset list and user list 2016-09-14 23:29:39 +08:00
__init__.py [Update] 迁移celery到ops 2018-04-02 13:19:31 +08:00
api.py [Update] Auth Info (#2806) 2019-06-19 11:31:38 +08:00
apps.py Api (#2439) 2019-02-26 12:38:20 +08:00
compat.py Finish access key auth 2016-12-25 13:15:28 +08:00
const.py Dev csv (#2640) 2019-05-21 16:24:01 +08:00
decorator.py Dev ansible windows 2 (#2783) 2019-06-13 18:58:43 +08:00
drfmetadata.py [Update] 修改api meta data 2019-05-16 14:41:11 +08:00
exceptions.py [Feature] 修改ansible和ops 2017-12-07 13:01:33 +08:00
mixins.py [Update] 修改资产创建格式 2019-06-19 19:25:21 +08:00
permissions.py [Update] 增加审计员权限控制 (#2792) 2019-06-19 10:47:26 +08:00
serializers.py [Update] 控制组织管理员不允许更新、删除超级用户;修复ViewSet API批量更新的bug (#2629) 2019-04-25 10:11:50 +08:00
signals.py [Update] 修改settings配置 (#2067) 2018-11-22 12:27:27 +08:00
tasks.py [Update] 邮件设置添加配置项:发送账号 (#2796) 2019-06-14 10:51:18 +08:00
tests.py add asset add 2016-09-03 19:05:50 +08:00
tree.py Bugfix (#2252) 2018-12-21 15:47:52 +08:00
validators.py Dev ansible windows 2 (#2783) 2019-06-13 18:58:43 +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()