Skip to main content

Shared models for FX Backend

Project description

FX Shared Models

A Django package containing shared models and configurations for the FX Backend system. This package provides base models for customers and system settings that can be extended using proxy models in your Django applications.

Features

  • Customer Models

    • Base customer model with essential fields
    • Customer settings and details
    • Customer authentication
    • Flexible proxy model support
  • System Settings Models

    • Email configuration management
    • System-wide settings
    • Extensible settings framework

Installation

You can install the package using pip:

pip install fx-shared-models

For development, you can install from source:

git clone https://github.com/yourusername/fx-shared-models.git
cd fx-shared-models
pip install -e .

Quick Start

  1. Add the shared models to your INSTALLED_APPS in settings.py:
INSTALLED_APPS = [
    ...
    'shared_models.customers.apps.CustomersConfig',  # Base models
    'shared_models.system_settings.apps.SystemSettingsConfig',  # Base system settings
    ...
]
  1. Create proxy models in your app:
# your_app/models.py
from shared_models.customers.models import Customer as BaseCustomer

class Customer(BaseCustomer):
    class Meta:
        proxy = True
        
    # Add your custom methods here

Usage Examples

Customer Models

# Using base customer model
from shared_models.customers.models import Customer

# Create a new customer
customer = Customer.objects.create(
    email='customer@example.com',
    first_name='John',
    last_name='Doe'
)

# Using proxy model in your app
from your_app.models import Customer

# Your custom methods will be available
customer = Customer.objects.create_customer(
    email='customer@example.com',
    first_name='John',
    last_name='Doe'
)

System Settings

from shared_models.system_settings.models import EmailConfiguration

# Create email configuration
email_config = EmailConfiguration.objects.create(
    name='SMTP Config',
    provider='smtp',
    from_email='noreply@example.com'
)

Model Structure

Customer Models

  • Customer: Base customer model with essential fields
    • Personal information (name, email, phone)
    • Status fields (is_funded, is_client, is_ib)
    • KYC status tracking
    • IB relationship management

System Settings Models

  • SystemSetting: Base settings model

    • Configuration management
    • Status tracking
    • Metadata storage
  • EmailConfiguration: Email provider settings

    • SMTP configuration
    • Provider management
    • Email templates

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Requirements

  • Python >= 3.8
  • Django >= 3.0
  • django-environ >= 0.10.0

Support

For support, please open an issue in the GitHub repository or contact the development team.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fx_shared_models-0.1.6.tar.gz (46.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fx_shared_models-0.1.6-py3-none-any.whl (61.4 kB view details)

Uploaded Python 3

File details

Details for the file fx_shared_models-0.1.6.tar.gz.

File metadata

  • Download URL: fx_shared_models-0.1.6.tar.gz
  • Upload date:
  • Size: 46.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for fx_shared_models-0.1.6.tar.gz
Algorithm Hash digest
SHA256 4b7698a888103ede40aefccf69fe2b6b9f9e7c893a9bc39f35e3f309cf566da4
MD5 3580f50c5cea42acb075c6f7db96b43b
BLAKE2b-256 c29dfcc0461e2cc34e69a5bd6c7770f7e105ce268d8169b4f3e7953ce660f292

See more details on using hashes here.

File details

Details for the file fx_shared_models-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for fx_shared_models-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 fdf344c7f90aca9f61b3c0baaf352be72ee25069c4a0a05f809c1ba5482391dd
MD5 8aee9b932d45353996f85d5e104665b3
BLAKE2b-256 6f2abc2e19552dd654b2a656f9abbc2f07494674fb9f3c16bc796809c19daca7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page