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.9.tar.gz (23.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.9-py3-none-any.whl (30.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django_chelseru-1.0.9.tar.gz
  • Upload date:
  • Size: 23.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.9.tar.gz
Algorithm Hash digest
SHA256 20abfd4aafe99216b89ce14b50f2984ef91e3cf6abcd0975e87bcb85bd47d8ae
MD5 3804df831eeba3619702e3c8f91aaa7a
BLAKE2b-256 6fd187feca6b0f3d3b4ee2d8781f9995a02693af62693c106bb9678a55ed6abf

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_chelseru-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 2acd9e6122ee5d465f7b93f5070afa73acc6938f16f47d75e919278232d7c434
MD5 d9b62e8a0ffe3c643515b02aa77dc965
BLAKE2b-256 10b51a5beca5a2debddd488a4a994449718c64e27b0af43f695c0f0afa9e4617

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