amsdal_crm 0.1.8__tar.gz → 0.1.9__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.
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/PKG-INFO +1 -1
- amsdal_crm-0.1.9/amsdal_crm/__about__.py +1 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/migrations/0000_initial.py +1 -1
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/deal.py +1 -2
- amsdal_crm-0.1.8/amsdal_crm/__about__.py +0 -1
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.amsdal/.environment +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.amsdal-cli +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.github/workflows/ci.yml +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.github/workflows/release.yml +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.github/workflows/tag_check.yml +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/.gitignore +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/CLAUDE.md +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/README.md +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/RELEASE.md +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/Third-Party Materials - AMSDAL Dependencies - License Notices.md +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/app.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/constants.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/errors.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/fixtures/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/fixtures/permissions.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/fixtures/pipelines.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/lifecycle/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/lifecycle/consumer.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/account.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/activity.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/attachment.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/contact.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/custom_field_definition.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/pipeline.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/stage.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/models/workflow_rule.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/activity_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/custom_field_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/deal_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/email_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/services/workflow_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/amsdal_crm/settings.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/config.yml +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/license_check.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/pyproject.toml +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/scripts/release.sh +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/scripts/tag_check.sh +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/conftest.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/conftest.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/services/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/services/test_deal_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/services/test_email_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/integration/services/test_workflow_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/conftest.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/lifecycle/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/lifecycle/test_consumer.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_account.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_activity.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_contact.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_deal.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_pipeline.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_remaining.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/models/test_stage.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/__init__.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/test_activity_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/test_custom_field_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/test_deal_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/test_email_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/services/test_workflow_service.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/test_app.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/test_constants.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/test_errors.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/tests/unit/test_settings.py +0 -0
- {amsdal_crm-0.1.8 → amsdal_crm-0.1.9}/uv.lock +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
__version__ = '0.1.9'
|
|
@@ -469,7 +469,7 @@ class Migration(migrations.Migration):
|
|
|
469
469
|
"is_won": {"type": "boolean", "default": False, "title": "Is Won"},
|
|
470
470
|
"custom_fields": {"type": "anything", "title": "Custom Fields"},
|
|
471
471
|
},
|
|
472
|
-
"custom_code": 'import datetime as _dt\n\nfrom amsdal.contrib.auth.models.user import User\nfrom amsdal_utils.models.data_models.reference import Reference\n\n\n@property\ndef display_name(self) -> str:\n """Return display name for the deal."""\n return self.name\n\n@property\ndef stage_name(self) -> str:\n """Returns stage name for display."""\n if hasattr(self.stage, \'name\'):\n return self.stage.name\n return str(self.stage)\n\nasync def apost_update(self) -> None:\n """Async hook called after updating deal."""\n from amsdal_crm.services.workflow_service import WorkflowService\n WorkflowService.execute_rules(\'Deal\', \'update\', self)\n\nasync def apre_create(self) -> None:\n """Async hook called before creating deal."""\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = await CustomFieldService.avalidate_custom_fields(\'Deal\', self.custom_fields)\n await super().apre_create()\n\nasync def apre_update(self) -> None:\n """Async hook called before updating deal.\n\n Automatically syncs is_closed and is_won status with stage,\n and sets closed_date when deal is closed.\n """\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = await CustomFieldService.avalidate_custom_fields(\'Deal\', self.custom_fields)\n
|
|
472
|
+
"custom_code": 'import datetime as _dt\n\nfrom amsdal.contrib.auth.models.user import User\nfrom amsdal_utils.models.data_models.reference import Reference\n\n\n@property\ndef display_name(self) -> str:\n """Return display name for the deal."""\n return self.name\n\n@property\ndef stage_name(self) -> str:\n """Returns stage name for display."""\n if hasattr(self.stage, \'name\'):\n return self.stage.name\n return str(self.stage)\n\nasync def apost_update(self) -> None:\n """Async hook called after updating deal."""\n from amsdal_crm.services.workflow_service import WorkflowService\n WorkflowService.execute_rules(\'Deal\', \'update\', self)\n\nasync def apre_create(self) -> None:\n """Async hook called before creating deal."""\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = await CustomFieldService.avalidate_custom_fields(\'Deal\', self.custom_fields)\n await super().apre_create()\n\nasync def apre_update(self) -> None:\n """Async hook called before updating deal.\n\n Automatically syncs is_closed and is_won status with stage,\n and sets closed_date when deal is closed.\n """\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = await CustomFieldService.avalidate_custom_fields(\'Deal\', self.custom_fields)\n stage = await self.stage\n self.is_closed = stage.is_closed_won or stage.is_closed_lost\n self.is_won = stage.is_closed_won\n if self.is_closed and (not self.closed_date):\n self.closed_date = _dt.datetime.now(_dt.UTC)\n await super().apre_update()\n\ndef has_object_permission(self, user: \'User\', action: str) -> bool:\n """Check if user has permission to perform action on this deal.\n\n Args:\n user: The user attempting the action\n action: The action being attempted (read, create, update, delete)\n\n Returns:\n True if user has permission, False otherwise\n """\n if self.owner_email == user.email:\n return True\n if user.permissions:\n for permission in user.permissions:\n if permission.model == \'*\' and permission.action in (\'*\', action):\n return True\n if permission.model == \'Deal\' and permission.action in (\'*\', action):\n return True\n return False\n\ndef post_update(self) -> None:\n """Hook called after updating deal."""\n from amsdal_crm.services.workflow_service import WorkflowService\n WorkflowService.execute_rules(\'Deal\', \'update\', self)\n\ndef pre_create(self) -> None:\n """Hook called before creating deal."""\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = CustomFieldService.validate_custom_fields(\'Deal\', self.custom_fields)\n super().pre_create()\n\ndef pre_update(self) -> None:\n """Hook called before updating deal.\n\n Automatically syncs is_closed and is_won status with stage,\n and sets closed_date when deal is closed.\n """\n if self.custom_fields:\n from amsdal_crm.services.custom_field_service import CustomFieldService\n self.custom_fields = CustomFieldService.validate_custom_fields(\'Deal\', self.custom_fields)\n from amsdal_models.classes.helpers.reference_loader import ReferenceLoader\n stage = ReferenceLoader(self.stage).load_reference() if isinstance(self.stage, Reference) else self.stage\n self.is_closed = stage.is_closed_won or stage.is_closed_lost\n self.is_won = stage.is_closed_won\n if self.is_closed and (not self.closed_date):\n self.closed_date = _dt.datetime.now(_dt.UTC)\n super().pre_update()',
|
|
473
473
|
"storage_metadata": {
|
|
474
474
|
"table_name": "Deal",
|
|
475
475
|
"db_fields": {
|
|
@@ -146,9 +146,8 @@ class Deal(TimestampMixin, Model):
|
|
|
146
146
|
self.custom_fields = await CustomFieldService.avalidate_custom_fields('Deal', self.custom_fields)
|
|
147
147
|
|
|
148
148
|
# Load stage if it's a reference and sync closed status
|
|
149
|
-
from amsdal_models.classes.helpers.reference_loader import ReferenceLoader
|
|
150
149
|
|
|
151
|
-
stage = await
|
|
150
|
+
stage = await self.stage
|
|
152
151
|
self.is_closed = stage.is_closed_won or stage.is_closed_lost
|
|
153
152
|
self.is_won = stage.is_closed_won
|
|
154
153
|
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
__version__ = '0.1.8'
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|