blob: bf14b837e99054427d6ad41ba9a3c8b2918ab749 [file] [log] [blame]
Sapan Bhatia7148c082017-06-16 15:04:11 -07001{% if options.legacy =='"True"' -%}
2{% set legacy_tag = '_decl' %}
3{% set legacy = True %}
4from core.models.xosbase import *
5{% else %}
6{% set legacy = False %}
7{% set legacy_tag = '' %}
Sapan Bhatia504cc972017-04-27 01:56:28 +02008from header import *
Sapan Bhatia7148c082017-06-16 15:04:11 -07009{% endif %}
Sapan Bhatia504cc972017-04-27 01:56:28 +020010
11{% for m in proto.messages %}
12{% if file_exists(m.name|lower+'_header.py') -%}from {{m.name|lower }}_header import *{% endif %}
13{% if file_exists(m.name|lower+'_top.py') -%}{{ include_file(m.name|lower+'_top.py') }} {% endif %}
14
Sapan Bhatia3cfdf632017-06-08 05:14:03 +020015{%- for l in m.links -%}{% set peer_name=l.peer.name %}
Sapan Bhatia00274172017-07-20 09:05:46 -040016
Sapan Bhatia3cfdf632017-06-08 05:14:03 +020017{% if peer_name not in proto.message_names -%}
18from core.models import {{ peer_name }}
Sapan Bhatia504cc972017-04-27 01:56:28 +020019{%- endif -%}
20{%- endfor -%}
21{%- for b in m.bases -%}
Sapan Bhatia3cfdf632017-06-08 05:14:03 +020022{%- if b.name!='XOSBase' and 'Mixin' not in b.name %}
Sapan Bhatia00274172017-07-20 09:05:46 -040023{% if b.name not in proto.message_names %}
Sapan Bhatia3cfdf632017-06-08 05:14:03 +020024from core.models import {{ b.name }}
Sapan Bhatia00274172017-07-20 09:05:46 -040025{% endif %}
Sapan Bhatia504cc972017-04-27 01:56:28 +020026{%- endif -%}
27{% endfor %}
28
Sapan Bhatia9227b4d2017-07-25 23:14:48 -040029{% for policy,error in xproto_validations(m.options) %}
30{{ xproto_fol_to_python_validator(policy, proto.policies[policy], m, error) }}
31{% endfor %}
32
Sapan Bhatia504cc972017-04-27 01:56:28 +020033{% endfor %}
34
35{% for m in proto.messages %}
Sapan Bhatiaa3d2e622017-07-31 22:25:55 -040036class {{ m.name }}{{ legacy_tag }}{{ xproto_base_def(m.name, m.bases, legacy_tag, proto.message_names) }}:
Sapan Bhatia2941a052017-07-10 15:10:03 -040037 plural_name = "{{ xproto_pluralize(m) }}"
Sapan Bhatia504cc972017-04-27 01:56:28 +020038
39 KIND = {{ xproto_first_non_empty([m.options.kind, options.kind, options.name, "Set a kind in your xproto!"]) }}
40
41 class Meta:
42 app_label = {{ xproto_first_non_empty([m.options.app_label, options.app_label, options.name, "Set an app label in your xproto!"]) | lower}}
43 # name = {{ xproto_first_non_empty([m.options.name, options.name, "Set a name in your xproto!"]) }}
44 verbose_name = {{ xproto_first_non_empty([m.options.verbose_name, options.verbose_name, "Set a verbose name in your xproto!"]) }}
45
46 # Primitive Fields (Not Relations)
47 {% for f in m.fields %}
48 {%- if not f.link -%}
49 {{ f.name }} = {{ xproto_django_type(f.type, f.options) }}( {{ xproto_django_options_str(f) }} )
50 {% endif %}
51 {%- endfor %}
52
53 # Relations
Sapan Bhatia3cfdf632017-06-08 05:14:03 +020054 {% for l in m.links %}{% set peer_name=l.peer.name %}
Sapan Bhatia7148c082017-06-16 15:04:11 -070055 {% if legacy and peer_name in proto.message_names %}{% set peer_tag = legacy_tag %}{% else %}{% set peer_tag = '' %}{% endif -%}
56 {{ l.src_port }} = {{ xproto_django_link_type(l) }}( {%- if peer_name==m.name -%}'self'{%- else -%}{{ peer_name }}{{ peer_tag }} {%- endif -%}, {{ xproto_django_options_str(l, l.dst_port ) }} )
Sapan Bhatia504cc972017-04-27 01:56:28 +020057 {%- endfor %}
58
59 {% if file_exists(m.name|lower + '_model.py') -%}{{ include_file(m.name|lower + '_model.py') | indent(width=2)}}{%- endif %}
60 pass
61
Sapan Bhatia9227b4d2017-07-25 23:14:48 -040062 # Generated methods
63 def save(self, *args, **kwds):
Sapan Bhatia113c2b92017-07-25 08:41:58 -040064 if not self.leaf_model_name:
65 self.leaf_model_name = "{{ m.name }}"
66
Sapan Bhatia9227b4d2017-07-25 23:14:48 -040067 try:
68 self.__xos_save_base(*args, **kwds)
69 except AttributeError:
70 pass
71
72 {% for policy,error in xproto_validations(m.options) %}
73 policy_{{policy}}_validator(self, None)
74 {% endfor %}
75 super({{ m.name }}{{ legacy_tag }}, self).save(*args, **kwds)
Sapan Bhatiab5ce1862017-07-31 15:48:19 -040076
77 def can_access(self, ctx):
78 {% if m.policy %}
79 verdict = security.{{m.policy}}_security_check(self, ctx)
80 return verdict,"{{ m.policy }}"
81 {% else %}
82 verdict = True
83 return verdict,"xos_default_policy"
84 {% endif %}
Sapan Bhatia9227b4d2017-07-25 23:14:48 -040085
Sapan Bhatia7148c082017-06-16 15:04:11 -070086{% if file_exists(m.name|lower+'_bottom.py') -%}{{ include_file(m.name|lower+'_bottom.py') }}{% endif %}
Sapan Bhatia504cc972017-04-27 01:56:28 +020087{% endfor %}
Sapan Bhatia2941a052017-07-10 15:10:03 -040088+++ models{{ legacy_tag }}.py