valar 0.0.2__tar.gz → 0.0.4__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of valar might be problematic. Click here for more details.
- {valar-0.0.2/valar.egg-info → valar-0.0.4}/PKG-INFO +1 -1
- {valar-0.0.2 → valar-0.0.4}/README.md +3 -0
- {valar-0.0.2 → valar-0.0.4}/setup.py +7 -3
- {valar-0.0.2 → valar-0.0.4/valar.egg-info}/PKG-INFO +1 -1
- valar-0.0.4/valar.egg-info/SOURCES.txt +14 -0
- valar-0.0.4/valar.egg-info/top_level.txt +3 -0
- valar-0.0.4/valar_base/apps.py +6 -0
- valar-0.0.4/valar_base/models.py +93 -0
- valar-0.0.4/valar_base/network.py +11 -0
- valar-0.0.4/valar_base/urls.py +8 -0
- valar-0.0.4/valar_common/__init__.py +0 -0
- valar-0.0.4/valar_meta/__init__.py +0 -0
- valar-0.0.2/vala/dao.py +0 -2
- valar-0.0.2/valar.egg-info/SOURCES.txt +0 -9
- valar-0.0.2/valar.egg-info/top_level.txt +0 -1
- {valar-0.0.2 → valar-0.0.4}/LICENSE.txt +0 -0
- {valar-0.0.2 → valar-0.0.4}/setup.cfg +0 -0
- {valar-0.0.2 → valar-0.0.4}/valar.egg-info/dependency_links.txt +0 -0
- {valar-0.0.2/vala → valar-0.0.4/valar_base}/__init__.py +0 -0
|
@@ -1,12 +1,16 @@
|
|
|
1
1
|
from setuptools import setup
|
|
2
|
+
NAME = 'valar'
|
|
3
|
+
VERSION = '0.0.4'
|
|
2
4
|
|
|
3
5
|
setup(
|
|
4
|
-
name=
|
|
5
|
-
version=
|
|
6
|
-
packages=['
|
|
6
|
+
name=NAME,
|
|
7
|
+
version=VERSION,
|
|
8
|
+
packages=['valar_base','valar_common','valar_meta'],
|
|
7
9
|
url='https://gitee.com/GRIFFIN120/valar',
|
|
8
10
|
license='MIT License',
|
|
9
11
|
author='刘寅鹏',
|
|
10
12
|
author_email='liuyinpeng@buaa.edu.cn',
|
|
11
13
|
description='Valar Margulis'
|
|
12
14
|
)
|
|
15
|
+
|
|
16
|
+
print(f'twine upload dist/{NAME}-{VERSION}.tar.gz ')
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
LICENSE.txt
|
|
2
|
+
README.md
|
|
3
|
+
setup.py
|
|
4
|
+
valar.egg-info/PKG-INFO
|
|
5
|
+
valar.egg-info/SOURCES.txt
|
|
6
|
+
valar.egg-info/dependency_links.txt
|
|
7
|
+
valar.egg-info/top_level.txt
|
|
8
|
+
valar_base/__init__.py
|
|
9
|
+
valar_base/apps.py
|
|
10
|
+
valar_base/models.py
|
|
11
|
+
valar_base/network.py
|
|
12
|
+
valar_base/urls.py
|
|
13
|
+
valar_common/__init__.py
|
|
14
|
+
valar_meta/__init__.py
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import uuid
|
|
2
|
+
|
|
3
|
+
from django.db import models
|
|
4
|
+
from django.db.models.fields.files import FieldFile
|
|
5
|
+
|
|
6
|
+
'''
|
|
7
|
+
基类,配合Dao使用
|
|
8
|
+
'''
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class BaseModel(models.Model):
|
|
12
|
+
uuid = models.UUIDField(default=uuid.uuid4, editable=False, verbose_name='标识')
|
|
13
|
+
sort = models.IntegerField(null=True, unique=True, verbose_name='序号')
|
|
14
|
+
name = models.CharField(max_length=255, null=True, verbose_name='名称')
|
|
15
|
+
description = models.TextField(null=True, verbose_name='描述')
|
|
16
|
+
date = models.DateField(null=True, verbose_name='日期')
|
|
17
|
+
enable = models.BooleanField(default=True, verbose_name='是否启用')
|
|
18
|
+
create_time = models.DateTimeField(auto_now_add=True, null=True, verbose_name='创建时间')
|
|
19
|
+
modify_time = models.DateTimeField(auto_now=True, null=True, verbose_name='修改时间')
|
|
20
|
+
_enable = models.BooleanField(default=True)
|
|
21
|
+
|
|
22
|
+
class Meta:
|
|
23
|
+
abstract = True
|
|
24
|
+
|
|
25
|
+
@property
|
|
26
|
+
def mapping(self):
|
|
27
|
+
mapping = {}
|
|
28
|
+
for field in self._meta.get_fields():
|
|
29
|
+
prop = field.name
|
|
30
|
+
domain = type(field).__name__
|
|
31
|
+
mapping[prop] = {'prop': prop, 'domain': domain, 'field': field}
|
|
32
|
+
return mapping
|
|
33
|
+
|
|
34
|
+
"""
|
|
35
|
+
只序列化基础字段:能用value_from_object直接取出的字段。与values等价
|
|
36
|
+
"""
|
|
37
|
+
|
|
38
|
+
@property
|
|
39
|
+
def json(self, fields={}):
|
|
40
|
+
mapping = self.mapping
|
|
41
|
+
excludes = ['ManyToOneRel', 'OneToOneRel', 'ManyToManyRel', 'ManyToManyField', 'UUIDField']
|
|
42
|
+
mapping = {prop: mapping[prop] for prop in mapping if mapping[prop]['domain'] not in excludes}
|
|
43
|
+
data = {}
|
|
44
|
+
for prop in mapping:
|
|
45
|
+
field = mapping[prop]['field']
|
|
46
|
+
domain = mapping[prop]['domain']
|
|
47
|
+
value = field.value_from_object(self)
|
|
48
|
+
if domain in ['ForeignKey', 'OneToOneField']:
|
|
49
|
+
prop = prop + '_id'
|
|
50
|
+
elif domain in ['DateField']:
|
|
51
|
+
value = value.strftime('%Y-%m-%d') if value else None
|
|
52
|
+
elif domain in ['DateTimeField']:
|
|
53
|
+
value = value.strftime('%Y-%m-%d %H:%M:%S') if value else None
|
|
54
|
+
elif domain in ['FileField']:
|
|
55
|
+
file: FieldFile = value
|
|
56
|
+
value = file.name
|
|
57
|
+
# elif domain in ['BigAutoField']:
|
|
58
|
+
# value = str(value)
|
|
59
|
+
data[prop] = value
|
|
60
|
+
return data
|
|
61
|
+
|
|
62
|
+
@property
|
|
63
|
+
def full(self):
|
|
64
|
+
data = self.json
|
|
65
|
+
mapping = self.mapping
|
|
66
|
+
excludes = ['ManyToManyField', 'ManyToManyRel', 'ForeignKey', 'ManyToOneRel', 'OneToOneField', 'OneToOneRel']
|
|
67
|
+
mapping = {prop: mapping[prop] for prop in mapping if mapping[prop]['domain'] in excludes}
|
|
68
|
+
for prop in mapping:
|
|
69
|
+
field = mapping[prop]['field']
|
|
70
|
+
domain = mapping[prop]['domain']
|
|
71
|
+
if domain in ['ForeignKey', 'OneToOneField', 'OneToOneRel']:
|
|
72
|
+
if hasattr(self, prop):
|
|
73
|
+
bean: BaseModel = getattr(self, prop)
|
|
74
|
+
data[prop] = bean.json if bean else None
|
|
75
|
+
elif domain in ['ManyToManyField', 'ManyToManyRel', 'ManyToOneRel']:
|
|
76
|
+
accessor = prop if domain == 'ManyToManyField' else field.get_accessor_name()
|
|
77
|
+
try:
|
|
78
|
+
_set = getattr(self, accessor).all()
|
|
79
|
+
data[prop] = [item.id for item in _set]
|
|
80
|
+
data[f'{prop}_set'] = [item.json for item in _set]
|
|
81
|
+
except Exception as e:
|
|
82
|
+
print(e)
|
|
83
|
+
pass
|
|
84
|
+
return data
|
|
85
|
+
|
|
86
|
+
|
|
87
|
+
class BaseTree(BaseModel):
|
|
88
|
+
pid = models.IntegerField(null=False, default=0, verbose_name='父节点')
|
|
89
|
+
node_type = models.IntegerField(null=False, default=1, verbose_name='节点类型') # 0 中间节点 1 末端节点
|
|
90
|
+
icon = models.CharField(max_length=255, null=True, verbose_name='图标')
|
|
91
|
+
|
|
92
|
+
class Meta:
|
|
93
|
+
abstract = True
|
|
File without changes
|
|
File without changes
|
valar-0.0.2/vala/dao.py
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
vala
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|