constec 0.2.0__tar.gz → 0.3.0__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.
Files changed (38) hide show
  1. {constec-0.2.0 → constec-0.3.0}/PKG-INFO +1 -1
  2. {constec-0.2.0 → constec-0.3.0}/constec/db/migrations/0001_initial.py +8 -2
  3. {constec-0.2.0 → constec-0.3.0}/constec/db/models/company.py +1 -0
  4. {constec-0.2.0 → constec-0.3.0}/constec/db/models/erp_entity.py +17 -2
  5. {constec-0.2.0 → constec-0.3.0}/constec/db/models/tag.py +2 -0
  6. {constec-0.2.0 → constec-0.3.0}/constec/db/models/user.py +2 -0
  7. {constec-0.2.0 → constec-0.3.0}/constec.egg-info/PKG-INFO +1 -1
  8. {constec-0.2.0 → constec-0.3.0}/constec.egg-info/SOURCES.txt +0 -2
  9. {constec-0.2.0 → constec-0.3.0}/pyproject.toml +1 -1
  10. constec-0.2.0/constec/db/migrations/0002_alter_companysystem_table_alter_connection_table_and_more.py +0 -37
  11. constec-0.2.0/constec/db/migrations/0003_add_is_active_to_company.py +0 -18
  12. {constec-0.2.0 → constec-0.3.0}/LICENSE +0 -0
  13. {constec-0.2.0 → constec-0.3.0}/README.md +0 -0
  14. {constec-0.2.0 → constec-0.3.0}/constec/db/__init__.py +0 -0
  15. {constec-0.2.0 → constec-0.3.0}/constec/db/apps.py +0 -0
  16. {constec-0.2.0 → constec-0.3.0}/constec/db/migrations/__init__.py +0 -0
  17. {constec-0.2.0 → constec-0.3.0}/constec/db/models/__init__.py +0 -0
  18. {constec-0.2.0 → constec-0.3.0}/constec/db/models/base.py +0 -0
  19. {constec-0.2.0 → constec-0.3.0}/constec/db/models/contact.py +0 -0
  20. {constec-0.2.0 → constec-0.3.0}/constec/db/models/erp.py +0 -0
  21. {constec-0.2.0 → constec-0.3.0}/constec/db/models/flow.py +0 -0
  22. {constec-0.2.0 → constec-0.3.0}/constec/db/models/group.py +0 -0
  23. {constec-0.2.0 → constec-0.3.0}/constec/db/models/module.py +0 -0
  24. {constec-0.2.0 → constec-0.3.0}/constec/db/models/organization.py +0 -0
  25. {constec-0.2.0 → constec-0.3.0}/constec/db/models/person.py +0 -0
  26. {constec-0.2.0 → constec-0.3.0}/constec/db/models/session.py +0 -0
  27. {constec-0.2.0 → constec-0.3.0}/constec/py.typed +0 -0
  28. {constec-0.2.0 → constec-0.3.0}/constec/services/__init__.py +0 -0
  29. {constec-0.2.0 → constec-0.3.0}/constec/services/encryption.py +0 -0
  30. {constec-0.2.0 → constec-0.3.0}/constec/shared/__init__.py +0 -0
  31. {constec-0.2.0 → constec-0.3.0}/constec/shared/exceptions.py +0 -0
  32. {constec-0.2.0 → constec-0.3.0}/constec/utils/__init__.py +0 -0
  33. {constec-0.2.0 → constec-0.3.0}/constec/utils/cuit.py +0 -0
  34. {constec-0.2.0 → constec-0.3.0}/constec/utils/password.py +0 -0
  35. {constec-0.2.0 → constec-0.3.0}/constec.egg-info/dependency_links.txt +0 -0
  36. {constec-0.2.0 → constec-0.3.0}/constec.egg-info/requires.txt +0 -0
  37. {constec-0.2.0 → constec-0.3.0}/constec.egg-info/top_level.txt +0 -0
  38. {constec-0.2.0 → constec-0.3.0}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: constec
3
- Version: 0.2.0
3
+ Version: 0.3.0
4
4
  Summary: Base library for the Constec ecosystem - shared utilities, models, and namespace foundation
5
5
  License: MIT
6
6
  Project-URL: Homepage, https://github.com/TpmyCT/constec-python
@@ -115,6 +115,7 @@ class Migration(migrations.Migration):
115
115
  ('legal_name', models.CharField(max_length=255)),
116
116
  ('slug', models.SlugField(max_length=100, unique=True)),
117
117
  ('website', models.URLField(blank=True, null=True)),
118
+ ('is_active', models.BooleanField(default=True)),
118
119
  ('parent_company', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='children', to='constec_db.company')),
119
120
  ('organization', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='companies', to='constec_db.organization')),
120
121
  ],
@@ -235,6 +236,11 @@ class Migration(migrations.Migration):
235
236
  'db_table': 'core"."persons',
236
237
  },
237
238
  ),
239
+ migrations.AddField(
240
+ model_name='entity',
241
+ name='company',
242
+ field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='erp_entities', to='constec_db.company'),
243
+ ),
238
244
  migrations.AddField(
239
245
  model_name='entity',
240
246
  name='person',
@@ -497,11 +503,11 @@ class Migration(migrations.Migration):
497
503
  ),
498
504
  migrations.AddIndex(
499
505
  model_name='entity',
500
- index=models.Index(fields=['system', 'cuit'], name='entities_system__347218_idx'),
506
+ index=models.Index(fields=['company', 'cuit'], name='entities_company_cuit_idx'),
501
507
  ),
502
508
  migrations.AlterUniqueTogether(
503
509
  name='entity',
504
- unique_together={('system', 'role', 'external_id')},
510
+ unique_together={('company', 'role', 'external_id')},
505
511
  ),
506
512
  migrations.AlterUniqueTogether(
507
513
  name='connection',
@@ -27,6 +27,7 @@ class Company(UUIDModel):
27
27
  class Meta:
28
28
  app_label = 'constec_db'
29
29
  db_table = 'core"."companies'
30
+ verbose_name_plural = 'Companies'
30
31
 
31
32
  def __str__(self):
32
33
  return self.name
@@ -1,5 +1,7 @@
1
+ from django.core.exceptions import ValidationError
1
2
  from django.db import models
2
3
  from .base import UUIDModel
4
+ from .company import Company
3
5
  from .erp import System
4
6
  from .person import Person
5
7
 
@@ -30,6 +32,11 @@ class Entity(UUIDModel):
30
32
  but no Core account yet). When they authenticate via CUIT, we can
31
33
  optionally link them to a Person later.
32
34
  """
35
+ company = models.ForeignKey(
36
+ Company,
37
+ on_delete=models.CASCADE,
38
+ related_name="erp_entities",
39
+ )
33
40
  person = models.ForeignKey(
34
41
  Person,
35
42
  on_delete=models.CASCADE,
@@ -63,12 +70,20 @@ class Entity(UUIDModel):
63
70
  class Meta:
64
71
  app_label = 'constec_db'
65
72
  db_table = '"erp"."entities"'
66
- unique_together = [['system', 'role', 'external_id']]
73
+ verbose_name_plural = 'Entities'
74
+ unique_together = [['company', 'role', 'external_id']]
67
75
  indexes = [
68
76
  models.Index(fields=['cuit']),
69
- models.Index(fields=['system', 'cuit']),
77
+ models.Index(fields=['company', 'cuit']),
70
78
  ]
71
79
 
80
+ def clean(self):
81
+ from .erp import CompanySystem
82
+ if not CompanySystem.objects.filter(company=self.company, system=self.system).exists():
83
+ raise ValidationError(
84
+ f"Company {self.company} is not associated with System {self.system}"
85
+ )
86
+
72
87
  def __str__(self):
73
88
  person_info = f"({self.person.full_name})" if self.person else "(no person linked)"
74
89
  return f"[{self.system.name}] {self.role.name} {self.external_id} {person_info}"
@@ -17,6 +17,8 @@ class TagCategory(UUIDModel):
17
17
  class Meta:
18
18
  app_label = 'constec_db'
19
19
  db_table = 'core"."tag_categories'
20
+ verbose_name = 'Tag category'
21
+ verbose_name_plural = 'Tag categories'
20
22
 
21
23
  def __str__(self):
22
24
  return f"{self.name}"
@@ -66,6 +66,8 @@ class UserCompanyAccess(UUIDModel):
66
66
  class Meta:
67
67
  app_label = 'constec_db'
68
68
  db_table = 'core"."user_company_access'
69
+ verbose_name = 'User company access'
70
+ verbose_name_plural = 'User company access'
69
71
  unique_together = [['user', 'company']]
70
72
 
71
73
  def __str__(self):
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: constec
3
- Version: 0.2.0
3
+ Version: 0.3.0
4
4
  Summary: Base library for the Constec ecosystem - shared utilities, models, and namespace foundation
5
5
  License: MIT
6
6
  Project-URL: Homepage, https://github.com/TpmyCT/constec-python
@@ -10,8 +10,6 @@ constec.egg-info/top_level.txt
10
10
  constec/db/__init__.py
11
11
  constec/db/apps.py
12
12
  constec/db/migrations/0001_initial.py
13
- constec/db/migrations/0002_alter_companysystem_table_alter_connection_table_and_more.py
14
- constec/db/migrations/0003_add_is_active_to_company.py
15
13
  constec/db/migrations/__init__.py
16
14
  constec/db/models/__init__.py
17
15
  constec/db/models/base.py
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "constec"
7
- version = "0.2.0"
7
+ version = "0.3.0"
8
8
  description = "Base library for the Constec ecosystem - shared utilities, models, and namespace foundation"
9
9
  readme = "README.md"
10
10
  requires-python = ">=3.9"
@@ -1,37 +0,0 @@
1
- # Generated by Django 6.0.1 on 2026-01-27 12:52
2
-
3
- from django.db import migrations
4
-
5
-
6
- class Migration(migrations.Migration):
7
-
8
- dependencies = [
9
- ('constec_db', '0001_initial'),
10
- ]
11
-
12
- operations = [
13
- migrations.AlterModelTable(
14
- name='companysystem',
15
- table='"erp"."company_systems"',
16
- ),
17
- migrations.AlterModelTable(
18
- name='connection',
19
- table='"erp"."connections"',
20
- ),
21
- migrations.AlterModelTable(
22
- name='entity',
23
- table='"erp"."entities"',
24
- ),
25
- migrations.AlterModelTable(
26
- name='entityauth',
27
- table='"erp"."entity_auth"',
28
- ),
29
- migrations.AlterModelTable(
30
- name='role',
31
- table='"erp"."roles"',
32
- ),
33
- migrations.AlterModelTable(
34
- name='system',
35
- table='"erp"."systems"',
36
- ),
37
- ]
@@ -1,18 +0,0 @@
1
- # Generated by Django 5.2.10 on 2026-01-27 13:07
2
-
3
- from django.db import migrations, models
4
-
5
-
6
- class Migration(migrations.Migration):
7
-
8
- dependencies = [
9
- ('constec_db', '0002_alter_companysystem_table_alter_connection_table_and_more'),
10
- ]
11
-
12
- operations = [
13
- migrations.AddField(
14
- model_name='company',
15
- name='is_active',
16
- field=models.BooleanField(default=True),
17
- ),
18
- ]
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes