Laravel IQ – Level 1 – Part 3

RMAG news

প্রশ্ন ৩১: Laravel-এ Service Provider-এর মাধ্যমে Dependency Injection কীভাবে ইমপ্লিমেন্ট করবেন?
উত্তর:
Laravel-এ Service Provider-এর মাধ্যমে Dependency Injection ইমপ্লিমেন্ট করার জন্য আপনি নিম্নলিখিত ধাপগুলো অনুসরণ করতে পারেন:

১. Service Provider তৈরি করা

Laravel-এ একটি নতুন Service Provider তৈরি করতে, আপনি Artisan কমান্ড ব্যবহার করতে পারেন:

php artisan make:provider ExampleServiceProvider

এটি app/Providers ডিরেক্টরিতে একটি নতুন ExampleServiceProvider ক্লাস তৈরি করবে।

২. Service Provider-এ Dependency Binding করা

Service Provider-এ নির্দিষ্ট ইন্টারফেস বা ক্লাসের জন্য কনক্রিট ইমপ্লিমেন্টেশন নির্ধারণ করতে হলে register মেথড ব্যবহার করা হয়।

উদাহরণস্বরূপ: ধরুন আপনার কাছে একটি PaymentServiceInterface এবং তার একটি কনক্রিট ইমপ্লিমেন্টেশন StripePaymentService আছে।

namespace AppProviders;

use IlluminateSupportServiceProvider;
use AppServicesPaymentServiceInterface;
use AppServicesStripePaymentService;

class ExampleServiceProvider extends ServiceProvider
{
    /**
     * Register services.
     *
     * @return void
     */
    public function register()
    {
        $this->app->bind(PaymentServiceInterface::class, StripePaymentService::class);
    }

    /**
     * Bootstrap services.
     *
     * @return void
     */
    public function boot()
    {
        //
    }
}

৩. Service Provider রেজিস্টার করা

Service Provider রেজিস্টার করতে আপনাকে config/app.php ফাইলের providers অ্যারের মধ্যে নতুন প্রোভাইডারটি যোগ করতে হবে:

'providers' => [
    // Other Service Providers
    AppProvidersExampleServiceProvider::class,
],

৪. Dependency Injection ব্যবহার করা

এখন, আপনি যেকোনো কন্ট্রোলার বা ক্লাসে PaymentServiceInterface টাইপহিন্টের মাধ্যমে StripePaymentService ইমপ্লিমেন্টেশনটি অটোমেটিক্যালি ইনজেক্ট করতে পারবেন।

কন্ট্রোলারের উদাহরণ:

namespace AppHttpControllers;

use AppServicesPaymentServiceInterface;

class PaymentController extends Controller
{
    protected $paymentService;

    public function __construct(PaymentServiceInterface $paymentService)
    {
        $this->paymentService = $paymentService;
    }

    public function processPayment()
    {
        $this->paymentService->process();
    }
}

৫. সেবা ইমপ্লিমেন্টেশন তৈরি করা

আপনার ইমপ্লিমেন্টেশন ক্লাসটি PaymentServiceInterface ইন্টারফেসটি বাস্তবায়ন করবে:

namespace AppServices;

class StripePaymentService implements PaymentServiceInterface
{
    public function process()
    {
        // Payment processing logic here
        return 'Payment processed via Stripe!';
    }
}

উপসংহার

এই পদ্ধতিতে আপনি Laravel-এ Service Provider-এর মাধ্যমে Dependency Injection ইমপ্লিমেন্ট করতে পারবেন। এটি আপনার কোডকে আরো মডুলার এবং টেস্টেবল করতে সহায়তা করে।

প্রশ্ন ৩২: Laravel-এ Multitenancy ইমপ্লিমেন্ট করার পদ্ধতি কী?
উত্তর:
Laravel-এ Multitenancy ইমপ্লিমেন্ট করা মানে একাধিক টেন্যান্ট (অর্থাৎ ভিন্ন ভিন্ন ক্লায়েন্ট বা ব্যবহারকারী গ্রুপ) সমর্থন করা, যেখানে প্রতিটি টেন্যান্টের ডেটা আলাদা থাকে। Multitenancy সাধারণত দুটি পদ্ধতিতে ইমপ্লিমেন্ট করা হয়:

১। Single Database Multitenancy (Row-based segregation)
প্রতিটি টেন্যান্টের ডেটা একই ডাটাবেসে আলাদা আলাদা রেকর্ড বা টেবিলের মাধ্যমে সংরক্ষণ করা হয়।

২। Multiple Database Multitenancy (Database per tenant)
প্রতিটি টেন্যান্টের জন্য আলাদা ডাটাবেস ব্যবহৃত হয়।

Single Database Multitenancy (Row-based segregation)

১। মাইগ্রেশন তৈরি করা
প্রতিটি টেন্যান্টের ডেটা আলাদা করতে একটি tenant_id ফিল্ড যোগ করুন:

php artisan make:migration add_tenant_id_to_users_table --table=users

মাইগ্রেশনে টেন্যান্ট আইডি যুক্ত করুন:

public function up()
{
    Schema::table('users', function (Blueprint $table) {
        $table->unsignedBigInteger('tenant_id')->index();
    });
}

২। মডেল আপডেট করা
মডেলে tenant_id প্রপার্টি যোগ করুন:

namespace AppModels;

use IlluminateDatabaseEloquentModel;

class User extends Model
{
    protected $fillable = ['tenant_id', 'name', 'email'];
}

৩। Global Scope ব্যবহার করা
প্রতিটি টেন্যান্টের ডেটা আলাদা করতে Global Scope ব্যবহার করুন:

namespace AppScopes;

use IlluminateDatabaseEloquentBuilder;
use IlluminateDatabaseEloquentModel;
use IlluminateDatabaseEloquentScope;

class TenantScope implements Scope
{
    public function apply(Builder $builder, Model $model)
    {
        $builder->where('tenant_id', session('tenant_id'));
    }
}

মডেলে স্কোপ প্রয়োগ করুন:

namespace AppModels;

use AppScopesTenantScope;
use IlluminateDatabaseEloquentModel;

class User extends Model
{
    protected static function booted()
    {
        static::addGlobalScope(new TenantScope());
    }
}

৪। টেন্যান্ট আইডি সেট করা
ব্যবহারকারীর লগইনের পর session-এ tenant_id সেট করুন:

session(['tenant_id' => $user->tenant_id]);

Multiple Database Multitenancy (Database per tenant)

১। প্রতিটি টেন্যান্টের জন্য ডাটাবেস তৈরি করুন
ডাটাবেস তৈরি করে টেন্যান্টের ডেটাবেস নাম tenants টেবিলে সংরক্ষণ করুন।

২। ডাটাবেস কানেকশন ডাইনামিক করা
AppServiceProvider-এ ডাইনামিক ডাটাবেস কানেকশন সেট করুন:

use IlluminateSupportFacadesDB;

public function boot()
{
    $tenant = session('tenant');
    if ($tenant) {
        config(['database.connections.tenant.database' => $tenant->database_name]);
        DB::purge('tenant');
        DB::reconnect('tenant');
    }
}

config/database.php-এ টেন্যান্ট ডাটাবেস কানেকশন যোগ করুন:

'tenant' => [
    'driver' => 'mysql',
    'host' => env('DB_HOST', '127.0.0.1'),
    'port' => env('DB_PORT', '3306'),
    'database' => '',
    'username' => env('DB_USERNAME', 'root'),
    'password' => env('DB_PASSWORD', ''),
    'charset' => 'utf8mb4',
    'collation' => 'utf8mb4_unicode_ci',
    'prefix' => '',
    'strict' => true,
    'engine' => null,
],

৩। মডেল ডাইনামিক ডাটাবেস ব্যবহার করা
প্রতিটি টেন্যান্টের ডেটার জন্য আলাদা কানেকশন ব্যবহার করুন:

    namespace AppModels;

    use IlluminateDatabaseEloquentModel;

    class TenantModel extends Model
    {
        protected $connection = 'tenant';
    }

প্যাকেজ ব্যবহার করে সহজে Multitenancy ইমপ্লিমেন্ট করা

Laravel-এ Multitenancy সহজে ইমপ্লিমেন্ট করার জন্য কিছু প্যাকেজ রয়েছে, যেমন:

  • Spatie Laravel Multitenancy
  • Tenancy for Laravel

এই প্যাকেজগুলো টেন্যান্সি পরিচালনা অনেক সহজ করে দেয় এবং ডাইনামিক ডাটাবেস কানেকশন, টেন্যান্ট স্কোপিং ইত্যাদি বিষয় সহজে সেটআপ করা যায়।

উপসংহার

Laravel-এ Multitenancy ইমপ্লিমেন্ট করার জন্য আপনার প্রয়োজন অনুযায়ী Single Database বা Multiple Database পদ্ধতি ব্যবহার করতে পারেন। প্যাকেজ ব্যবহার করলে কাস্টম ইমপ্লিমেন্টেশনের ঝামেলা কমবে।

প্রশ্ন ৩৩: Laravel Telescope কী এবং এটি কেন ব্যবহার করা হয়?
উত্তর:
Laravel Telescope কী?

Laravel Telescope হলো Laravel-এর জন্য একটি ডেভেলপার টুল, যা অ্যাপ্লিকেশনের বিভিন্ন কার্যকলাপ পর্যবেক্ষণ এবং ডিবাগ করার জন্য ব্যবহার করা হয়। এটি Real-time Debugging এবং Application Monitoring এর সুবিধা প্রদান করে। Telescope ডেটা সংগ্রহ করে একটি ভিজ্যুয়াল ইন্টারফেসের মাধ্যমে প্রদর্শন করে, যা ডেভেলপারদের ডিবাগিং ও কর্মক্ষমতা বিশ্লেষণকে সহজ করে তোলে।

Laravel Telescope-এর গুরুত্বপূর্ণ ফিচার

Telescope নিম্নলিখিত বিষয়গুলো মনিটর এবং প্রদর্শন করতে পারে:

1. Request Monitoring:

  • HTTP অনুরোধ (Request URI, Method, Status Code ইত্যাদি)।
  • Request Body এবং Headers।

2. Database Queries:

  • Database-এর সমস্ত SQL কুয়েরি এবং তাদের সময়কাল মনিটর করা যায়।

3. Exception Tracking:

  • অ্যাপ্লিকেশনে ঘটানো সমস্ত এক্সসেপশন (Exception) দেখা যায়।

4. Queue Jobs:

  • কিউ সিস্টেমে কোন জব রান হচ্ছে এবং কোনটি ব্যর্থ হয়েছে তা দেখা যায়।

5. Scheduled Tasks:

  • ক্রন জব বা Laravel Scheduler-এর কাজগুলো মনিটর করা যায়।

6. Cache Monitoring:

  • ক্যাশ সেট, রিট্রাইভ এবং ডিলিট অপারেশন দেখা যায়।

7. Events Monitoring:

  • Laravel ইভেন্টগুলো ট্র্যাক করা যায়।

8. Authentication Activity:

  • ব্যবহারকারীর লগইন ও লগআউট কার্যকলাপ মনিটর করা যায়।

9. Mail Tracking:

  • মেইলগুলো কখন, কাকে এবং কী ধরনের পাঠানো হয়েছে তা দেখা যায়।

10. Custom Monitoring:

  • ডেভেলপাররা নিজস্ব লগ বা ডেটা মনিটর করার জন্য কাস্টম ট্যাপ (tap) যোগ করতে পারে।

Laravel Telescope কেন ব্যবহার করা হয়?

1. Debugging সহজ করা:

  • Telescope রিয়েল-টাইমে ডেটা প্রদান করে, যা ডেভেলপারদের অ্যাপ্লিকেশনের সমস্যাগুলো দ্রুত শনাক্ত করতে সাহায্য করে।

2. Performance Analysis:

  • SQL কুয়েরি এবং অন্যান্য প্রসেস মনিটর করে, যেখানে অপ্টিমাইজেশনের প্রয়োজন তা সহজে চিহ্নিত করা যায়।

3. Error Tracking:

  • Exceptions এবং ব্যর্থ Queue Jobs মনিটর করার মাধ্যমে সমস্যার উৎস বোঝা সহজ হয়।

4. Development Insights:

  • অ্যাপ্লিকেশন কিভাবে কাজ করছে, সেটি বুঝতে সাহায্য করে।

5. Custom Monitoring:

  • প্রয়োজন অনুযায়ী নতুন ডেটা সংগ্রহ ও মনিটরিংয়ের জন্য কাস্টমাইজেশন সুবিধা।

Laravel Telescope ইনস্টলেশন এবং কনফিগারেশন

1. Telescope ইনস্টল করা:
Composer এর মাধ্যমে Telescope ইনস্টল করুন:

composer require laravel/telescope

2. Telescope ইনস্টলেশনের জন্য কমান্ড চালান:

php artisan telescope:install
php artisan migrate

3. Service Provider রেজিস্টার করা (Development Mode):
AppServiceProvider ক্লাসে শুধু ডেভেলপমেন্ট এনভায়রনমেন্টের জন্য Telescope চালু করুন:

use LaravelTelescopeTelescope;

public function register()
{
    if ($this->app->isLocal()) {
        $this->app->register(LaravelTelescopeTelescopeServiceProvider::class);
        $this->app->register(TelescopeServiceProvider::class);
    }
}

4. Telescope অ্যাক্সেস করা:
অ্যাপ্লিকেশনের URL-এ /telescope যোগ করে Telescope-এর ড্যাশবোর্ডে প্রবেশ করতে পারবেন:

http://your-app.test/telescope

5. পাবলিশ কনফিগারেশন ফাইল (ঐচ্ছিক):

php artisan vendor:publish --tag=telescope-config

Laravel Telescope ব্যবহারের সীমাবদ্ধতা

1. Performance Impact:
Telescope ডেটা সংগ্রহের সময় সামান্য পারফরম্যান্সে প্রভাব ফেলতে পারে। তাই এটি সাধারণত ডেভেলপমেন্ট এনভায়রনমেন্টে ব্যবহার করা হয়।

2. Production Environment:
প্রোডাকশন পরিবেশে ব্যবহার করলে অতিরিক্ত রিসোর্স ব্যবহারের কারণে অ্যাপ্লিকেশনের কর্মক্ষমতা কমতে পারে। তবে প্রোডাকশন মনিটরিংয়ের জন্য ফিল্টার বা নির্দিষ্ট ডেটা সংগ্রহ সীমিত করা যায়।

উপসংহার

Laravel Telescope একটি শক্তিশালী টুল যা ডেভেলপারদের ডিবাগিং, মনিটরিং এবং অ্যাপ্লিকেশন ইনসাইট বুঝতে সাহায্য করে। এটি বিশেষ করে ডেভেলপমেন্ট পর্যায়ে ব্যবহার করা হয় এবং অ্যাপ্লিকেশনের কার্যকলাপ বিশ্লেষণে অমূল্য সহায়তা প্রদান করে।

Please follow and like us:
Pin Share