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.3.tar.gz (45.4 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.3-py3-none-any.whl (60.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fx_shared_models-0.1.3.tar.gz
  • Upload date:
  • Size: 45.4 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.3.tar.gz
Algorithm Hash digest
SHA256 616c9544200786ea5052595821e10a723f786e309248a039ac0a79ac040b8c5a
MD5 c9b9b081aba1a8128f65d84c264dcdfb
BLAKE2b-256 d14d2346b789fd980b6868f102c92038e0dfac3a4263f22ce21f853facb400e6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for fx_shared_models-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d0a7f64fd57a56a00b119108fc58f0e4e616423e32cc955d3946f3b16a97234c
MD5 b7bb562f29d99307c2e341ad58cd359f
BLAKE2b-256 1d714e474a419ba264902fee8ed4d1011770f7920cc2e6fac66d873c24f38442

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