Skip to main content

Authentication system, online and real-time chat, SMS system for Iranian SMS services.

Project description

django-chelseru

بستهٔ جنگویی برای گپ‌زنی همزمان (WebSocket)، راستی‌آزمایی پیامکی (OTP) و فرستادن پیامک با یاری‌دهنده‌های ایرانی.

نویسنده: Sobhan Bahman Rashnu


فهرست مطالب


ویژگی‌ها

  • 📱 راستی‌آزمایی پیامکی (OTP): تولید و فرستادن رمز یک‌بارمصرف و اعتبارسنجی امن.
  • 💬 گپ‌زنی همزمان: پیام‌رسانی همزمان بر پایهٔ WebSocket/Channels.
  • ✉️ فرستادن پیامک: پشتیبانی از یاری‌دهنده‌های نام‌آشنای ایرانی.

نصب

pip install django-chelseru

پیش‌نیازها و افزودن به تنظیمات

INSTALLED_APPS را در settings.py به‌روز کنید:

INSTALLED_APPS = [
    # ...
    'channels',
    'rest_framework',
    'rest_framework_simplejwt',
    'drfchelseru',
    # ...
]

نکته: برای قابلیت‌های همزمان (WebSocket) پروژهٔ شما باید با ASGI اجرا شود (مانند daphne یا uvicorn).


پیکربندی

واژه‌نامهٔ DJANGO_CHELSERU را در settings.py بیفزایید و بر اساس نیاز خود سفارشی‌سازی کنید:

DJANGO_CHELSERU = {
    'AUTH': {
        'AUTH_METHOD': 'OTP',  # روش‌های پشتیبانی‌شده: OTP, PASSWD
        'AUTH_SERVICE': 'rest_framework_simplejwt',  # فعلاً: rest_framework_simplejwt
        'OPTIONS': {
            'OTP_LENGTH': 8,                 # پیش‌فرض: 8
            'OTP_EXPIRE_PER_MINUTES': 4,     # پیش‌فرض: 4
            'OTP_SMS_TEMPLATE_ID': 1,        # شناسهٔ قالب پیامکی OTP
        },
    },
    'SMS': {
        'SMS_SERVICE': 'PARSIAN_WEBCO_IR',  # PARSIAN_WEBCO_IR, MELI_PAYAMAK_COM, KAVENEGAR_COM
        'SETTINGS': {
            'PARSIAN_WEBCO_IR_API_KEY': '',
            'MELI_PAYAMAK_COM_USERNAME': '',
            'MELI_PAYAMAK_COM_PASSWORD': '',
            'MELI_PAYAMAK_COM_FROM': '',
            'KAVENEGAR_COM_API_KEY': 'YOUR_KAVENEGAR_API_KEY',
            'KAVENEGAR_COM_FROM': 'YOUR_KAVENEGAR_FROM_NUMBER',
        },
        'TEMPLATES': {
            'T1': 1,
            'T2': 2,
            # ...
        },
    },
}

راهنما:

  • AUTH_METHOD: روش راستی‌آزمایی (برای پیامکی از 'OTP' استفاده کنید).
  • OTP_LENGTH: طول رمز یک‌بارمصرف.
  • OTP_EXPIRE_PER_MINUTES: مدت اعتبار رمز (به دقیقه).
  • OTP_SMS_TEMPLATE_ID: شناسهٔ قالب پیامکی که برای OTP بهره‌گیری می‌شود.
  • SMS_SERVICE: انتخاب یاری‌دهندهٔ پیامکی.
  • SETTINGS: مقادیر دسترسی یاری‌دهندهٔ انتخاب‌شده.
  • TEMPLATES: نگاشت کلیدهای دلخواه به شناسهٔ قالب‌ها.

تعریف آدرس‌ها (URLs)

در urls.py:

from django.urls import path, include

urlpatterns = [
    # ...
    path('api/', include('drfchelseru.urls')),
    # ...
]

نقطه‌های پایانی API

مسیر شرح روش
/api/otp/send/ فرستادن رمز یک‌بارمصرف به شمارهٔ همراه POST
/api/authenticate/ راستی‌آزمایی کاربر با OTP و دریافت توکن‌های JWT POST
/api/sessions/ فهرست و مدیریت نشست‌های فعال کاربر (نیازمند احراز) GET
/api/message/send/ فرستادن پیامک با یاری‌دهندهٔ پیکربندی‌شده POST

/api/otp/send/ — فرستادن رمز یک‌بارمصرف

روش: POST
شرح: یک OTP به شمارهٔ همراه کاربر فرستاده می‌شود.

بدنهٔ درخواست:

فیلد نوع شرح نمونه
mobile_number str شمارهٔ همراه کاربر 09121234567

نمونهٔ درخواست:

POST /api/otp/send/ HTTP/1.1
Content-Type: application/json

{
  "mobile_number": "09121234567"
}

پاسخ‌های ممکن:

  • 200 OK
    { "details": "The OTP code was sent correctly." }
    
  • 400 Bad Request — ساختار نادرست mobile_number
  • 409 Conflict
    { "details": "An OTP code has already been sent. Please wait X seconds before trying again." }
    
  • 500 Internal Server Error — خطا در کارگذار

/api/authenticate/ — راستی‌آزمایی با OTP و دریافت JWT

روش: POST
شرح: اعتبارسنجی کاربر با OTP؛ در صورت موفقیت، توکن‌های access و refresh بازگردانده می‌شود.

بدنهٔ درخواست:

فیلد نوع شرح نمونه
mobile_number str شمارهٔ همراه کاربر 09121234567
code str رمز یک‌بارمصرف دریافت‌شده 12345678
group int (اختیاری) شناسهٔ گروه کاربر 1

نمونهٔ درخواست:

POST /api/authenticate/ HTTP/1.1
Content-Type: application/json

{
  "mobile_number": "09121234567",
  "code": "12345678",
  "group": 1
}

پاسخ‌های ممکن:

  • 200 OK
    { "access": "...", "refresh": "..." }
    
  • 401 Unauthorized
    { "error": "The code sent to this mobile number was not found." }
    
  • 400 Bad Request — فیلدهای الزامی ناپیدا/نامعتبر
  • 500 Internal Server Error — خطا در کارگذار

/api/message/send/ — فرستادن پیامک

روش: POST
شرح: فرستادن پیامک سفارشی با یاری‌دهندهٔ پیکربندی‌شده.

بدنهٔ درخواست:

فیلد نوع شرح نمونه
mobile_number str شمارهٔ همراه گیرنده 09121234567
message_text str متن پیام (حداکثر ۲۹۰ نویسه) Hello, World!
template_id int (برای برخی یاری‌دهنده‌ها مانند پارسیان الزامی) 1

نمونهٔ درخواست:

POST /api/message/send/ HTTP/1.1
Content-Type: application/json

{
  "mobile_number": "09121234567",
  "message_text": "Hello, World!",
  "template_id": 1
}

پاسخ‌های ممکن:

  • 200 OK
    { "details": "The Message was sent correctly." }
    
  • 400 Bad Request — خطاهای اعتبارسنجی فیلدها
  • 401 Unauthorized — احراز انجام نشده
  • 500 Internal Server Error — خطا در کارگذار
  • 502 Bad Gateway — خطای بازگشتی از یاری‌دهندهٔ پیامکی

/api/sessions/ — فهرست نشست‌های فعال

روش: GET
شرح: همهٔ نشست‌های فعال کاربر را برمی‌گرداند. نیازمند احراز هویت (IsAuthenticated).

سربرگ‌های لازم:

سربرگ مقدار
Authorization Bearer <your_access_token>

نمونهٔ درخواست:

GET /api/sessions/ HTTP/1.1
Authorization: Bearer <your_access_token>

مدل‌ها

این بسته یک مدل Session برای مدیریت نشست‌های فعال کاربران فراهم می‌کند.
از طریق نقطهٔ پایانی /api/sessions/ می‌توانید نشست‌ها را مشاهده/مدیریت کنید.

Project details


Download files

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

Source Distribution

django_chelseru-1.0.8.tar.gz (22.9 kB view details)

Uploaded Source

Built Distribution

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

django_chelseru-1.0.8-py3-none-any.whl (29.1 kB view details)

Uploaded Python 3

File details

Details for the file django_chelseru-1.0.8.tar.gz.

File metadata

  • Download URL: django_chelseru-1.0.8.tar.gz
  • Upload date:
  • Size: 22.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.1

File hashes

Hashes for django_chelseru-1.0.8.tar.gz
Algorithm Hash digest
SHA256 3529653fb78415edc2eee549f38fcd519a2d1cecd582436cc34ac910548d1c7b
MD5 77fa5fac35ac7e6a95d91976ba60d358
BLAKE2b-256 e61f7323212d0c1e2542134955b4e7383141f3dd5079d0dfe3aa85ce97d55930

See more details on using hashes here.

File details

Details for the file django_chelseru-1.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for django_chelseru-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 595d84c8afc15c8aea548cbb15eefc0d38ef869c493eb1a1a9060a408634de0b
MD5 08b942dc36dae01932e62751e88157d6
BLAKE2b-256 4cad21d8504e6ed5ef93d9beb72e589c883a0316159c1f2563c0d8357269b4f7

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