Blog

লারাভেল ডিরেক্টরি স্ট্রাকচার, Root এবং app ডিরেক্টরির সকল ফাইলের ব্যবহার এবং বিস্তারিত আলোচনা

Laravel-এর ডিরেক্টরি স্ট্রাকচার একটি ওয়েব অ্যাপ্লিকেশন তৈরি করার জন্য খুবই সুসংগঠিত এবং কাঠামোবদ্ধ। এখানে Laravel 11-এর ডিরেক্টরি স্ট্রাকচারের মূল অংশগুলো উল্লেখ করা হলো:

অর্থাৎ Laravel-এর ডিরেক্টরি স্ট্রাকচারটি একটি সংগঠিত এবং কার্যকরী ফরম্যাটে ডিজাইন করা হয়েছে, যা ডেভেলপারদের জন্য কাজ করা সহজ করে। এই স্ট্রাকচারটি বিভিন্ন ফাইল এবং ফোল্ডারকে তাদের ফাংশন অনুযায়ী শ্রেণীবদ্ধ করে, যাতে অ্যাপ্লিকেশনের বিভিন্ন অংশ সহজে পরিচালনা করা যায়।

 

Laravel Directory Structure

এখানে Laravel অ্যাপ্লিকেশন তৈরি করার পর যে ডিরেক্টরি স্ট্রাকচারটি পাওয়া যায় তা নিচে উল্লেখ করা হলো:

app/
   Console/
   Exceptions/
   Http/
       Controllers/
       Middleware/
   Models/
   Policies/
bootstrap/
   cache/
config/
database/
   factories/
   migrations/
   seeders/
public/
resources/
   css/
   js/
   views/
routes/
storage/
   app/
   framework/
   logs/
tests/
vendor/
.env
.artisan
composer.json
package.json
phpunit.xml
README.md
 

লারাভেল ডিরেক্টরি স্ট্রাকচার এর সংক্ষিপ্ত রুপ 

your-laravel-app/
│
├── app/                # অ্যাপ্লিকেশনের লজিক
├── bootstrap/          # অ্যাপ্লিকেশন শুরু করার ফাইল
├── config/             # কনফিগারেশন ফাইল
├── database/           # ডাটাবেসের মাইগ্রেশন, সিডার, ফ্যাক্টরি
├── public/             # পাবলিক ফাইল (CSS, JS, Images)
├── resources/          # ভিউ ফাইল, ভাষা ফাইল, অন্যান্য রিসোর্স
├── routes/             # রাউট কনফিগারেশন
├── storage/            # লগ, ক্যাশে, এবং অস্থায়ী ফাইল
├── tests/              # টেস্ট কেস
└── vendor/             # Composer প্যাকেজ
 

 

ডিরেক্টরি ও ফাইলের ব্যাখ্যা:

1. app/

এই ফোল্ডারটি অ্যাপ্লিকেশনের মূল লজিক ধারণ করে। এখানে মডেল, কন্ট্রোলার, মিডলওয়্যার এবং অন্যান্য ক্লাস থাকে।

  • Console/: Artisan কমান্ড সংরক্ষণ করে।
  • Exceptions/: কাস্টম এক্সেপশন হ্যান্ডলিং সংরক্ষণ করে।
  • Http/: HTTP সম্পর্কিত কোড (Controllers, Middleware, Requests) থাকে।
  • Models/: ডাটাবেস মডেলগুলি সংরক্ষণ করে।
  • Providers/: সার্ভিস প্রোভাইডারগুলি সংরক্ষণ করে, যা অ্যাপ্লিকেশন শুরু করার সময় বিভিন্ন সার্ভিস রেজিস্টার করে।

2. bootstrap/

এটি অ্যাপ্লিকেশন শুরু করার জন্য প্রয়োজনীয় ফাইল ধারণ করে। app.php ফাইলটি এখানে থাকে, যা অ্যাপ্লিকেশনকে লোড এবং কনফিগার করতে ব্যবহৃত হয়।

3. config/

অ্যাপ্লিকেশনের কনফিগারেশন ফাইলগুলি এখানে থাকে, যা বিভিন্ন সেটিংস এবং কনফিগারেশন মান ধারণ করে।

4. database/

এই ফোল্ডারে ডাটাবেস মাইগ্রেশন, সিডার এবং ফ্যাক্টরি ফাইল থাকে। মাইগ্রেশনগুলো ডাটাবেস স্কিমা পরিবর্তন করার জন্য ব্যবহৃত হয়।

5. public/

এটি অ্যাপ্লিকেশনের পাবলিক ফাইলগুলি ধারণ করে, যেমন CSS, JavaScript, এবং ইমেজ। এটি লারাভেল অ্যাপ্লিকেশনের এন্ট্রি পয়েন্ট।

6. resources/

এখানে ভিউ ফাইল, ভাষা ফাইল এবং অন্যান্য রিসোর্স থাকে। Blade টেমপ্লেট এবং স্থানীয়করণ(Localization) ফাইলগুলোও এই ফোল্ডারে রয়েছে।

7. routes/

অ্যাপ্লিকেশনের রাউট কনফিগারেশন ফাইলগুলো এখানে থাকে। প্রতিটি রাউট অ্যাপ্লিকেশনের URL এবং তার সাথে সম্পর্কিত কন্ট্রোলার সংযুক্ত করে।

8. storage/

লগ, ক্যাশে, সেশন এবং অস্থায়ী ফাইল সংরক্ষণ করে। এটি তিনটি সাব-ডিরেক্টরি ধারণ করে:

  • app/: অ্যাপ্লিকেশনের ফাইল সঞ্চয় করে।
  • framework/: ফ্রেমওয়ার্কের জন্য প্রয়োজনীয় ক্যাশে এবং সেশন ফাইল।
  • logs/: লগ ফাইলগুলি এখানে থাকে।

9. tests/

অ্যাপ্লিকেশনের টেস্ট কেস সংরক্ষণ করা হয়। এখানে PHPUnit টেস্ট ফাইলগুলো থাকে।

10. vendor/

Composer দ্বারা ইনস্টল করা সমস্ত প্যাকেজ সংরক্ষণ করে। এটি আপনার অ্যাপ্লিকেশনের জন্য ব্যবহৃত তৃতীয় পক্ষের লাইব্রেরি ধারণ করে।

উপসংহার

Laravel-এর ডিরেক্টরি স্ট্রাকচারটি একটি শক্তিশালী এবং কার্যকরী ভিত্তি প্রদান করে, যা ডেভেলপারদের জন্য কোড সংরক্ষণ, পরিচালনা এবং উন্নয়ন প্রক্রিয়াকে সহজ করে। এই সংগঠিত স্ট্রাকচারটি বড় এবং জটিল অ্যাপ্লিকেশন তৈরি করতে সাহায্য করে এবং অ্যাপ্লিকেশনের বিভিন্ন অংশকে পৃথক করে রাখে, যাতে কোডটি আরও রক্ষণাবেক্ষণযোগ্য হয়।

 

The App Directory Structure

Laravel 11-এর App Directory হল অ্যাপ্লিকেশনের প্রধান অংশ, যেখানে সমস্ত ব্যবসায়িক(Business) লজিক, কন্ট্রোলার, মডেল এবং অন্যান্য গুরুত্বপূর্ণ উপাদান রাখা হয়। এই ডিরেক্টরির বিভিন্ন অংশ এবং তাদের উদ্দেশ্য সম্পর্কে বিস্তারিত জানানো হলো:

app/
├── Console/
├── Exceptions/
├── Http/
│   ├── Controllers/
│   ├── Middleware/
│   └── Requests/
├── Models/
├── Policies/
└── Providers/
 

১. Console/

এই ফোল্ডারটি Laravel-এর Artisan কমান্ড তৈরি করার জন্য ব্যবহৃত হয়। আপনি যদি কাস্টম Artisan কমান্ড তৈরি করতে চান, তবে আপনার কোড এখানে থাকবে।

উদাহরণ:

namespace App\Console\Commands;
use Illuminate\Console\Command;
class ExampleCommand extends Command
{
   protected $signature = 'example:command';
   protected $description = 'Example command description';
   public function handle()
   {
       // Command logic
   }
}
 

২. Exceptions/

এখানে কাস্টম এক্সেপশন হ্যান্ডলার এবং অন্যান্য ত্রুটির ক্লাস থাকে। Laravel-এর Handler ক্লাসটি এখানে থাকে, যা অ্যাপ্লিকেশনকে ত্রুটিগুলি পরিচালনা করতে সাহায্য করে।

উদাহরণ:

namespace App\Exceptions;
use Exception;
class CustomException extends Exception
{
   // Custom logic for handling exceptions
}
 

৩. Http/

এই ডিরেক্টরির মধ্যে HTTP সম্পর্কিত কোডগুলো সংরক্ষিত হয়:

Controllers/: এখানে অ্যাপ্লিকেশনের কন্ট্রোলার ক্লাসগুলো থাকে। কন্ট্রোলারগুলি রিকুয়েস্ট এবং রেসপন্স পরিচালনা করে এবং মডেল ও ভিউ-এর মধ্যে সমন্বয় সাধন করে।

উদাহরণ:

namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\Http\Request;
class UserController extends Controller
{
   public function index()
   {
       $users = User::all();
       return view('users.index', compact('users'));
   }
}
 

Middleware/: মিডলওয়্যার হলো অ্যাপ্লিকেশনের রিকুয়েস্ট এবং রেসপন্সের মধ্যে একটি প্রক্রিয়া। এটি সাধারণত রিকুয়েস্টের আগে বা পরে কিছু নির্দিষ্ট কাজ সম্পাদন করে।

উদাহরণ:

namespace App\Http\Middleware;
use Closure;
class CheckAge
{
   public function handle($request, Closure $next)
   {
       if ($request->age < 18) {
           return redirect('home');
       }
       return $next($request);
   }
}
 

Requests/: এই ফোল্ডারে কাস্টম রিকুয়েস্ট ভ্যালিডেশন ক্লাসগুলো থাকে, যা ইনপুট ডাটা যাচাই করার জন্য ব্যবহৃত হয়।

উদাহরণ:

namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
class StoreUserRequest extends FormRequest
{
   public function rules()
   {
       return [
           'name' => 'required|string|max:255',
           'email' => 'required|string|email|max:255|unique:users',
           'password' => 'required|string|min:8|confirmed',
       ];
   }
}
 

৪. Models/

মডেলগুলি ডাটাবেস টেবিলের প্রতিনিধিত্ব করে এবং সেই টেবিলের সাথে সম্পর্কিত কার্যক্রম (CRUD) পরিচালনা করে। মডেলগুলি ডেটা ম্যানিপুলেশন এবং ব্যবসায়িক(Business) লজিক পরিচালনা করার জন্য ব্যবহৃত হয়।

উদাহরণ:

namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
   protected $fillable = ['name', 'email', 'password'];
}
 

৫. Policies/

পলিসি ক্লাসগুলো অ্যাক্সেস কন্ট্রোলের জন্য ব্যবহৃত হয়। এটি নির্ধারণ করে যে ইউজার একটি নির্দিষ্ট রিসোর্সে প্রবেশের অনুমতি পাবে কিনা।

উদাহরণ:

namespace App\Policies;
use App\Models\User;
use App\Models\Post;
class PostPolicy
{
   public function update(User $user, Post $post)
   {
       return $user->id === $post->user_id;
   }
}
 

৬. Providers/

সার্ভিস প্রোভাইডারগুলি অ্যাপ্লিকেশন শুরু করার সময় বিভিন্ন সার্ভিস এবং কনফিগারেশন রেজিস্টার করে। এটি Laravel অ্যাপ্লিকেশনটির হৃদয়(herat), যেখানে সার্ভিসগুলোকে প্যাকেজের মাধ্যমে এবং কাস্টম কনফিগারেশন দিয়ে রেজিস্টার করা হয়।

উদাহরণ:

namespace App\Providers;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
{
   public function register()
   {
       // Register services
   }
   public function boot()
   {
       // Bootstrap services
   }
}
 

উপসংহার

Laravel 11-এর App Directory হলো অ্যাপ্লিকেশনের কেন্দ্রবিন্দু, যেখানে ব্যবসায়িক লজিক, ডাটাবেস মডেল, কন্ট্রোলার, মিডলওয়্যার এবং পলিসি ক্লাসগুলো রাখা হয়। এই সংগঠিত স্ট্রাকচার ডেভেলপারদের জন্য অ্যাপ্লিকেশন তৈরি এবং রক্ষণাবেক্ষণ সহজ করে, এবং এটি বড় এবং জটিল অ্যাপ্লিকেশনগুলোর জন্য একটি  পরিচ্ছন্ন ও সুসংহত কোডবেস নিশ্চিত করে।

 

 

লারাভেল ১১ এ নিম্নের ডিরেক্টরিগুলো ডিফল্টভাবে থাকেনা, আর্টিসান কমান্ড চালিয়ে পাওয়া যায়

Laravel 11-এর App Directory-তে কিছু ডিরেক্টরি ডিফল্টভাবে উপস্থিত থাকে না, তবে Artisan কমান্ডের মাধ্যমে সেগুলো তৈরি করা যায়। নিচে সেই ডিরেক্টরিগুলোর তালিকা এবং কীভাবে Artisan কমান্ড ব্যবহার করে সেগুলো তৈরি করা যায়, তা নিয়ে বিস্তারিত আলোচনা করা হলো।

১. Models/ (মডেল)

Laravel 11-এ Models ডিরেক্টরি ডিফল্টভাবে থাকে না। আপনি Artisan কমান্ড চালিয়ে মডেল তৈরি করলে এটি স্বয়ংক্রিয়ভাবে তৈরি হয়।

কমান্ড:

php artisan make:model Models/User

এটি app/Models/ ডিরেক্টরির অধীনে User.php নামে একটি মডেল তৈরি করবে। Models ডিরেক্টরি যদি না থাকে, তাহলে এটি তৈরি হবে।

 

২. Console/ (কনসোল কমান্ড)

Laravel-এর কাস্টম Artisan কমান্ড তৈরি করার জন্য Console ডিরেক্টরি ব্যবহার করা হয়, যা ডিফল্টভাবে থাকে না।

কমান্ড:

php artisan make:command ExampleCommand

এটি app/Console/Commands/ ডিরেক্টরির অধীনে ExampleCommand.php নামে একটি নতুন কনসোল কমান্ড তৈরি করবে। যদি Console/ এবং Commands/ ডিরেক্টরি না থাকে, তাহলে Laravel এটি তৈরি করে নেবে।

 

৩. Jobs/ (জব)

Laravel Queue-এর জন্য Jobs ক্লাস তৈরি করা হয়, যা Artisan কমান্ডের মাধ্যমে তৈরি করা যেতে পারে।

কমান্ড:

php artisan make:job SendEmailJob

এটি app/Jobs/ ডিরেক্টরির অধীনে SendEmailJob.php নামে একটি জব তৈরি করবে। Jobs ডিরেক্টরি না থাকলে Laravel এটি স্বয়ংক্রিয়ভাবে তৈরি করবে।

 

৪. Events/ (ইভেন্ট)

Laravel-এর ইভেন্ট মেকানিজম পরিচালনার জন্য Events ডিরেক্টরি ব্যবহার করা হয়, যা ডিফল্টভাবে থাকে না। Artisan কমান্ড দিয়ে এটি তৈরি করা যেতে পারে।

কমান্ড:

php artisan make:event UserRegistered

এটি app/Events/ ডিরেক্টরির অধীনে UserRegistered.php নামে একটি ইভেন্ট ক্লাস তৈরি করবে। যদি Events ডিরেক্টরি না থাকে, তাহলে এটি তৈরি করা হবে।

 

৫. Listeners/ (লিসেনার)

Laravel ইভেন্ট লিসেনারের জন্য Listeners ডিরেক্টরি ব্যবহার করা হয়, যা Artisan কমান্ডের মাধ্যমে তৈরি করা যায়।

কমান্ড:

php artisan make:listener SendWelcomeEmail

এটি app/Listeners/ ডিরেক্টরির অধীনে SendWelcomeEmail.php নামে একটি লিসেনার তৈরি করবে। Listeners ডিরেক্টরি যদি না থাকে, তাহলে এটি তৈরি হবে।

৬. Policies/ (পলিসি)

Laravel-এ পলিসি ক্লাস তৈরি করার জন্য Policies ডিরেক্টরি ব্যবহার করা হয়, যা ডিফল্টভাবে থাকে না।

কমান্ড:

php artisan make:policy UserPolicy

এটি app/Policies/ ডিরেক্টরির অধীনে UserPolicy.php তৈরি করবে। Policies ডিরেক্টরি যদি না থাকে, তাহলে এটি স্বয়ংক্রিয়ভাবে তৈরি হবে।

৭. Observers/ (অবজারভার)

Laravel-এর মডেল ইভেন্টগুলো পরিচালনার জন্য Observers ডিরেক্টরি ব্যবহার করা হয়। এটি Artisan কমান্ড দিয়ে তৈরি করা যায়।

কমান্ড:

php artisan make:observer UserObserver --model=User

এটি app/Observers/ ডিরেক্টরির অধীনে UserObserver.php নামে একটি অবজারভার তৈরি করবে। Observers ডিরেক্টরি না থাকলে এটি তৈরি হবে।

 

৮. Mail/ (মেইল)

Laravel মেইল ক্লাসের জন্য Mail ডিরেক্টরি তৈরি করা যায়, যা ডিফল্টভাবে থাকে না।

কমান্ড:

 

php artisan make:mail WelcomeMail

এটি app/Mail/ ডিরেক্টরির অধীনে WelcomeMail.php নামে একটি মেইল ক্লাস তৈরি করবে। Mail ডিরেক্টরি না থাকলে এটি তৈরি হবে।

 

৯. Notifications/ (নোটিফিকেশন)

Laravel-এ নোটিফিকেশন ক্লাস তৈরি করার জন্য Notifications ডিরেক্টরি ব্যবহার করা হয়, যা Artisan কমান্ড দিয়ে তৈরি করা যেতে পারে।

কমান্ড:

php artisan make:notification InvoicePaid

এটি app/Notifications/ ডিরেক্টরির অধীনে InvoicePaid.php নামে একটি নোটিফিকেশন তৈরি করবে। Notifications ডিরেক্টরি যদি না থাকে, তাহলে এটি তৈরি হবে।

 

১০. Rules/ (কাস্টম ভ্যালিডেশন রুল)

Laravel-এ কাস্টম ভ্যালিডেশন রুল তৈরি করার জন্য Rules ডিরেক্টরি ব্যবহার করা হয়।

কমান্ড:

php artisan make:rule ValidEmail

এটি app/Rules/ ডিরেক্টরির অধীনে ValidEmail.php নামে একটি কাস্টম রুল তৈরি করবে। Rules ডিরেক্টরি যদি না থাকে, তাহলে এটি স্বয়ংক্রিয়ভাবে তৈরি হবে।

উপসংহার

Laravel 11-এর App Directory-তে বেশ কিছু ডিরেক্টরি ডিফল্টভাবে থাকে না। তবে Artisan কমান্ডের মাধ্যমে এগুলো তৈরি করা যায়। Artisan কমান্ড Laravel ডেভেলপমেন্টকে আরও সুনির্দিষ্ট ও দ্রুততর করে তোলে এবং প্রয়োজন অনুযায়ী স্বয়ংক্রিয়ভাবে ডিরেক্টরি তৈরি করতে সক্ষম।


 

Laravel 11-এ আরও কিছু ডিরেক্টরি আছে, যেগুলো ডিফল্টভাবে অন্তর্ভুক্ত থাকে না। প্রয়োজন হলে আপনি সেগুলো Artisan কমান্ড ব্যবহার করে তৈরি করতে পারেন। নিচে অতিরিক্ত কিছু ডিরেক্টরির তালিকা দেওয়া হলো, যেগুলো Laravel 11-এ ডিফল্টভাবে থাকে না:

১১. app/Repositories/

Laravel-এ Repositories প্যাটার্ন ব্যবহৃত হলে, ডেটা অ্যাক্সেস লেয়ার আলাদা করার জন্য এই ডিরেক্টরি তৈরি করা যেতে পারে। এটি ডিফল্টভাবে উপস্থিত থাকে না এবং আপনাকে এটি ম্যানুয়ালি বা Artisan কমান্ড দিয়ে তৈরি করতে হয়।

 

১২. app/Services/

Services ডিরেক্টরি সাধারণত সার্ভিস ক্লাস বা বিজনেস লজিক সংরক্ষণের জন্য ব্যবহৃত হয়। Laravel ডিফল্টভাবে এই ডিরেক্টরি সরবরাহ করে না, তবে আপনি এটি নিজে তৈরি করতে পারেন।

 

১৩. app/Traits/

যদি আপনি বিভিন্ন ক্লাসে পুনঃব্যবহারযোগ্য ফাংশনালিটি তৈরি করতে চান, তাহলে Traits ব্যবহার করা হয়। এই ডিরেক্টরি ডিফল্টভাবে অন্তর্ভুক্ত নয়।

 

১৪. app/Helpers/

Helpers ডিরেক্টরি সাধারণত সহায়ক ফাংশন সংরক্ষণের জন্য ব্যবহৃত হয়। Laravel এটি ডিফল্টভাবে সরবরাহ করে না। আপনাকে নিজে এটি তৈরি করতে হয়।

 

১৫. app/Http/ViewComposers/

যদি আপনি View Composers ব্যবহার করেন, তাহলে এই ডিরেক্টরি তৈরি করা প্রয়োজন। এটি ডিফল্টভাবে অন্তর্ভুক্ত থাকে না।

 

১৬. app/Contracts/

Contracts ডিরেক্টরি ইন্টারফেস সংরক্ষণের জন্য ব্যবহৃত হয়। এটি সাধারণত ডিপেন্ডেন্সি ইনজেকশন ব্যবহারের সময় গুরুত্বপূর্ণ ভূমিকা পালন করে, তবে Laravel-এ ডিফল্টভাবে উপস্থিত নয়।

 

১৭. resources/lang/ (ভাষা ফাইল)

ডিফল্টভাবে শুধুমাত্র ইংরেজি ভাষার ফাইল Laravel-এ থাকে। অন্যান্য ভাষার জন্য আলাদা ডিরেক্টরি তৈরি করতে হয়, যেমন resources/lang/bn/ বাংলা ভাষার জন্য।

 

১৮. resources/js/components/

যদি আপনি Vue.js বা অন্যান্য ফ্রন্টএন্ড ফ্রেমওয়ার্ক ব্যবহার করেন, তবে JavaScript Components সংরক্ষণের জন্য এই ডিরেক্টরি ব্যবহার করা হয়। Laravel ডিফল্টভাবে এটি তৈরি করে না।

 

১৯. tests/Feature/ এবং tests/Unit/

যদিও ডিফল্টভাবে Laravel-এ কিছু টেস্ট ডিরেক্টরি থাকে, আপনি নির্দিষ্ট ইউনিট বা ফিচার টেস্টগুলোর জন্য এই ডিরেক্টরিগুলোকে আরও সংগঠিতভাবে তৈরি করতে পারেন।

 

২০. app/Http/Requests/

ফর্ম ভ্যালিডেশনের জন্য Form Request ক্লাস তৈরি করার সময় এটি তৈরি হয়। Laravel-এ ডিফল্টভাবে এটি উপস্থিত থাকে না।

 

২১. app/ViewModels/

View Models সাধারণত Vue.js বা Blade টেমপ্লেটের সাথে ডেটা ম্যানিপুলেশন এবং উপস্থাপনার জন্য ব্যবহৃত হয়। Laravel-এ ডিফল্টভাবে এটি নেই, তবে আপনি View Model প্যাটার্ন ব্যবহার করলে এটি তৈরি করতে পারেন।

 

২২. app/Facades/

Facades Laravel-এ সরাসরি কনটেইনারে অ্যাক্সেসের একটি উপায়, তবে আপনি যদি কাস্টম Facades তৈরি করতে চান, তাহলে এই ডিরেক্টরি ম্যানুয়ালি বা Artisan কমান্ডের মাধ্যমে তৈরি করতে হবে।

২৩. app/Http/Middleware/

Laravel-এ কিছু ডিফল্ট মিডলওয়্যার থাকে, তবে আপনি কাস্টম Middleware তৈরি করলে এটি app/Http/ ডিরেক্টরির অধীনে তৈরি করতে পারেন।

কমান্ড:

php artisan make:middleware CustomMiddleware

 

২৪. app/Http/Controllers/Admin/

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

 

২৫. app/Http/Controllers/API/

API রিসোর্সের জন্য আলাদা কন্ট্রোলার তৈরি করতে চাইলে আপনি API ডিরেক্টরি ম্যানুয়ালি তৈরি করতে পারেন। Laravel এটিকে ডিফল্টভাবে অন্তর্ভুক্ত করে না।

 

২৬. app/Scopes/

Global Scopes তৈরি করার জন্য Scopes ডিরেক্টরি ব্যবহৃত হয়। ডিফল্টভাবে এই ডিরেক্টরি অন্তর্ভুক্ত নয়, তবে আপনি Artisan কমান্ডের মাধ্যমে এটি তৈরি করতে পারেন।

কমান্ড:

php artisan make:scope CustomScope

 

২৭. app/Http/Resources/

Laravel-এ API রিসোর্সের জন্য Resources ক্লাস তৈরি করার সময় এই ডিরেক্টরি তৈরি হয়। ডিফল্টভাবে Laravel-এ এটি থাকে না।

কমান্ড:

php artisan make:resource UserResource

 

২৮. app/Traits/Requests/

যদি ফর্ম ভ্যালিডেশন বা HTTP অনুরোধগুলোর জন্য আলাদা Traits তৈরি করতে হয়, তবে এই ডিরেক্টরি ম্যানুয়ালি তৈরি করতে হবে। Laravel এটিকে ডিফল্টভাবে অন্তর্ভুক্ত করে না।

 

২৯. app/Http/Services/

আলাদা সার্ভিস ক্লাস তৈরি করার জন্য Services ডিরেক্টরি ব্যবহার করা হয়। এটি সাধারণত অ্যাপ্লিকেশনের বিজনেস লজিক পরিচালনার জন্য ব্যবহৃত হয়, কিন্তু Laravel এটিকে ডিফল্টভাবে তৈরি করে না।

 

৩০. storage/logs/custom/

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

 

৩১. storage/app/public/

ডিফল্টভাবে এই ডিরেক্টরি অন্তর্ভুক্ত থাকে না। আপনাকে ফাইল আপলোডের জন্য পাবলিক ডিরেক্টরি ম্যানুয়ালি তৈরি করতে হতে পারে।

৩২. public/css/ এবং public/js/

Laravel-এ সাধারণত ফ্রন্টএন্ড সম্পদ ব্যবস্থাপনার জন্য public/css/ এবং public/js/ ডিরেক্টরি ম্যানুয়ালি তৈরি করতে হয়। Laravel ডিফল্টভাবে এগুলো অন্তর্ভুক্ত করে না।

 

এছাড়াও Laravel 11-এ আরও কিছু ডিরেক্টরি রয়েছে, যেগুলো ডিফল্টভাবে তৈরি হয় না, তবে আপনার প্রয়োজন অনুযায়ী ম্যানুয়ালি বা Artisan কমান্ড দিয়ে সেগুলো তৈরি করা যায়। এগুলো অ্যাপ্লিকেশন স্ট্রাকচার এবং মডুলার ডিজাইনের ওপর নির্ভর করে তৈরি হয়। নিচে আরও কিছু ডিরেক্টরি উল্লেখ করা হলো, যেগুলো ডিফল্টভাবে উপস্থিত থাকে না:

৩৩. app/Transformers/

Laravel API ডেভেলপমেন্টের ক্ষেত্রে ডেটা ট্রান্সফরমেশন করার জন্য Transformers ডিরেক্টরি ব্যবহার করা হয়। এটি ডিফল্টভাবে উপস্থিত থাকে না, তবে আপনি এটি API-এর ডেটা ট্রান্সফরম করার প্রয়োজন হলে ম্যানুয়ালি তৈরি করতে পারেন।

 

৩৪. app/Http/Pipelines/

যদি আপনি Laravel-এ Pipeline প্যাটার্ন ব্যবহার করেন, তাহলে এই ডিরেক্টরি প্রয়োজন হতে পারে। Pipelines ক্লাসগুলো চেইনড প্রসেসিংয়ে ব্যবহৃত হয়, এবং ডিফল্টভাবে এই ডিরেক্টরি থাকে না।

 

৩৫. app/Http/Repositories/Eloquent/

Repositories প্যাটার্ন ব্যবহার করে Eloquent মডেল পরিচালনা করার জন্য আপনি Repositories/Eloquent ডিরেক্টরি তৈরি করতে পারেন। এটি ডিফল্টভাবে অন্তর্ভুক্ত নয়, তবে উন্নত অ্যাপ্লিকেশন কাঠামোতে ব্যবহৃত হতে পারে।

 

৩৬. app/Interfaces/

Interfaces ডিরেক্টরি সাধারণত বিভিন্ন ইন্টারফেস সংরক্ষণ এবং নির্দিষ্ট ডিপেন্ডেন্সি ইনজেকশনের জন্য ব্যবহৃত হয়। এটি Laravel-এ ডিফল্টভাবে থাকে না এবং প্রয়োজন অনুযায়ী ম্যানুয়ালি তৈরি করতে হয়।

 

৩৭. app/Observers/

মডেল ইভেন্ট অবজারভার তৈরি করার জন্য Observers ডিরেক্টরি ব্যবহার করা হয়। যদিও এটি আগেও উল্লেখ করা হয়েছে, Laravel ডিফল্টভাবে এটি অন্তর্ভুক্ত করে না এবং আপনাকে এটি তৈরি করতে হবে।

 

৩৮. app/Presenters/

Presenters Laravel-এ ভিউ এবং ডেটার মধ্যবর্তী স্তরে ব্যবহৃত হয়। এটি ডিফল্টভাবে অন্তর্ভুক্ত থাকে না এবং ম্যানুয়ালি তৈরি করতে হয়।

 

৩৯. app/Http/DTOs/ (Data Transfer Objects)

Laravel-এ ডেটা ট্রান্সফার করার জন্য DTOs (Data Transfer Objects) তৈরি করা হয়। এটি অ্যাপ্লিকেশনের ভ্যালিডেশন ও ডেটা ম্যানিপুলেশনের জন্য ব্যবহৃত হয়, কিন্তু ডিফল্টভাবে এই ডিরেক্টরি থাকে না।

 

৪০. app/Http/Bindings/

কাস্টম সার্ভিস প্রোভাইডার বা ক্লাসের সাথে bindings ব্যবহারের জন্য Bindings ডিরেক্টরি তৈরি করা যেতে পারে। এটি ডিফল্টভাবে উপস্থিত থাকে না।

 

৪১. database/seeds/

Laravel 11-এ সাধারণত factories ব্যবহৃত হয়, তবে seeds ডিরেক্টরি ডিফল্টভাবে থাকে না। তবে আপনি এটি ম্যানুয়ালি তৈরি করতে পারেন ডেটা সিডিংয়ের জন্য।

 

৪২. resources/views/emails/

Laravel ইমেইল টেমপ্লেট ব্যবহারের জন্য আলাদা views/emails/ ডিরেক্টরি তৈরি করা যেতে পারে। এটি ডিফল্টভাবে উপস্থিত থাকে না এবং প্রয়োজন অনুযায়ী ম্যানুয়ালি তৈরি করতে হয়।

 

৪৩. storage/framework/cache/

Cache ফাইলগুলো সংরক্ষণের জন্য এই ডিরেক্টরি ব্যবহার করা হয়। তবে Laravel-এ এই ডিরেক্টরি ডিফল্টভাবে থাকে না, এবং ক্যাশিং সেটআপের সময় এটি তৈরি করা হয়।

 

৪৪. public/storage/

ফাইল আপলোড সংরক্ষণের জন্য public/storage/ ডিরেক্টরি প্রয়োজন হতে পারে, কিন্তু এটি ডিফল্টভাবে অন্তর্ভুক্ত নয়। Laravel-এ এটি লিংক করার জন্য php artisan storage:link কমান্ড ব্যবহার করতে হয়।

 

৪৫. tests/Browser/

Laravel Dusk বা ব্রাউজার টেস্টিং ব্যবহারের সময় Browser ডিরেক্টরি তৈরি করা হয়। এটি ডিফল্টভাবে উপস্থিত নয় এবং Dusk ইনস্টল করলে এটি তৈরি হয়।

 

৪৬. app/Http/Queries/

Queries ডিরেক্টরি Eloquent Query Object প্যাটার্নের জন্য ব্যবহৃত হতে পারে, যেখানে কাস্টম কুয়েরি লজিককে পুনরায় ব্যবহারযোগ্য এবং সংগঠিত রাখা হয়। এটি ডিফল্টভাবে অন্তর্ভুক্ত থাকে না।

 

৪৭. app/Http/Forms/

ফর্ম হ্যান্ডলিংয়ের জন্য Laravel-এ আলাদা ফর্ম ক্লাস তৈরি করা হলে Forms ডিরেক্টরি ব্যবহার করা যেতে পারে। এটি সাধারণত বড় অ্যাপ্লিকেশনগুলিতে ব্যবহৃত হয় এবং Laravel-এ ডিফল্টভাবে থাকে না।

 

৪৮. app/Pipelines/

Laravel-এ Pipeline প্যাটার্ন ব্যবহার করা হলে কাস্টম পিপলাইনের জন্য Pipelines ডিরেক্টরি তৈরি করা হয়। এটি অ্যাপ্লিকেশন লজিককে ধাপে ধাপে প্রসেস করার সুবিধা দেয়। ডিফল্টভাবে Laravel এই ডিরেক্টরি তৈরি করে না।

 

৪৯. config/services/

কিছু সময়ে কাস্টম সার্ভিস কনফিগারেশন পরিচালনার জন্য আপনি services.php ফাইল তৈরি করতে পারেন। যদি একাধিক সার্ভিস কনফিগার করা থাকে, তাহলে আপনি কনফিগ ফোল্ডারে services/ ডিরেক্টরি তৈরি করে প্রতিটি সার্ভিসের জন্য আলাদা কনফিগ ফাইল রাখতে পারেন। এটি Laravel-এর ডিফল্ট স্ট্রাকচারে অন্তর্ভুক্ত নয়।

 

৫০. app/Rules/Custom/

কাস্টম ভ্যালিডেশন রুল তৈরি করার জন্য আপনি এই ডিরেক্টরি ব্যবহার করতে পারেন। Laravel-এ ডিফল্টভাবে এটি অন্তর্ভুক্ত থাকে না, তবে আপনি কাস্টম রুল তৈরি করলে এটি দরকার হতে পারে।

কমান্ড:

php artisan make:rule CustomRule

 

৫১. app/Http/Filters/

Laravel-এ কাস্টম ফিল্টার তৈরি করা হলে Filters ডিরেক্টরি ব্যবহার করা হয়। এটি ডাটাবেজ বা API কুয়েরির ক্ষেত্রে বিশেষভাবে প্রযোজ্য। Laravel-এ এটি ডিফল্টভাবে অন্তর্ভুক্ত নয়।

 

৫২. app/Http/Middleware/Admin/

বড় অ্যাপ্লিকেশনগুলিতে অ্যাডমিন সম্পর্কিত কাস্টম মিডলওয়্যার তৈরি করা হলে, আপনি Middleware/Admin/ ডিরেক্টরি ব্যবহার করতে পারেন। ডিফল্টভাবে এটি অন্তর্ভুক্ত নয়।

 

৫৩. app/Http/Middleware/User/

User বা Frontend User সংক্রান্ত মিডলওয়্যার পরিচালনার জন্য আলাদা ডিরেক্টরি দরকার হতে পারে, যেখানে কাস্টম লজিক প্রয়োগ করা হয়। ডিফল্টভাবে এই ডিরেক্টরি Laravel-এ থাকে না।

 

৫৪. public/images/

প্রজেক্টে ইমেজ ফাইল সংরক্ষণের জন্য public/images/ ডিরেক্টরি তৈরি করতে হয়। Laravel এই ডিরেক্টরি ডিফল্টভাবে সরবরাহ করে না, তবে ইমেজ বা অন্যান্য মিডিয়া সংরক্ষণের জন্য এটি তৈরি করা যেতে পারে।

 

৫৫. public/assets/

স্ট্যাটিক অ্যাসেট (CSS, JS, ফন্ট) সংরক্ষণের জন্য assets/ ডিরেক্টরি তৈরি করা যেতে পারে। Laravel এটি ডিফল্টভাবে অন্তর্ভুক্ত করে না, তবে আপনি ফ্রন্টএন্ড ফাইলগুলি রাখতে এটি তৈরি করতে পারেন।

 

৫৬. storage/app/backups/

Laravel-এ ডেটাবেস বা ফাইল সিস্টেমের ব্যাকআপ ফাইল সংরক্ষণের জন্য backups/ ডিরেক্টরি ব্যবহার করা যেতে পারে। এটি ডিফল্টভাবে তৈরি হয় না, তবে ব্যাকআপ ব্যবস্থাপনার জন্য প্রয়োজন হতে পারে।

 

৫৭. storage/temp/

কোনো ফাইল বা ডেটা সাময়িকভাবে সংরক্ষণ করার জন্য temp/ ডিরেক্টরি ব্যবহার করা যেতে পারে। এটি Laravel-এর ডিফল্ট স্ট্রাকচারে থাকে না এবং প্রয়োজন হলে এটি ম্যানুয়ালি তৈরি করতে হয়।

 

৫৮. database/blueprints/

ডাটাবেজ স্কিমার ব্লুপ্রিন্ট সংরক্ষণের জন্য blueprints/ ডিরেক্টরি তৈরি করা যেতে পারে। এটি সাধারণত বড় অ্যাপ্লিকেশনে ব্যবহৃত হয়, কিন্তু Laravel ডিফল্টভাবে এটি তৈরি করে না।

 

৫৯. resources/svg/

SVG ফাইলগুলো সংরক্ষণের জন্য resources/svg/ ডিরেক্টরি তৈরি করা যায়। Laravel-এ এটি ডিফল্টভাবে অন্তর্ভুক্ত নয়, তবে ফ্রন্টএন্ডে কাজ করার সময় এটি দরকার হতে পারে।

 

৬০. app/Http/Requests/API/

API রিকোয়েস্ট হ্যান্ডলিংয়ের জন্য আলাদা Requests/API/ ডিরেক্টরি তৈরি করা যেতে পারে। বড় API ভিত্তিক অ্যাপ্লিকেশনগুলিতে এই ধরনের আলাদা ডিরেক্টরি কাঠামো ব্যবহার করা হয়। Laravel ডিফল্টভাবে এটি অন্তর্ভুক্ত করে না।

উপসংহার

Laravel 11-এ বেশ কিছু ডিরেক্টরি ডিফল্টভাবে উপস্থিত থাকে না, তবে অ্যাপ্লিকেশন ডেভেলপমেন্টের সময় আপনার নির্দিষ্ট প্রয়োজন অনুযায়ী আপনি এসব ডিরেক্টরি ম্যানুয়ালি বা Artisan কমান্ড ব্যবহার করে তৈরি করতে পারেন। Laravel-এর এই ফ্লেক্সিবল ডিরেক্টরি স্ট্রাকচার উন্নত অ্যাপ্লিকেশন গঠন ও মডুলারাইজেশনকে সহজ করে তোলে।

580

Author

FOUNDER OF SATT
1.4k Followers

পেশা ব্যাংকিং কিন্তু প্যাশন প্রোগ্রামিং, প্রোগ্রামিং দিয়েই বিশ্ব জয়ের পথে এখন স্যাট এর সাথে।

All Comments

Md. RAKIBUL HASAN 1 month ago
Nice
Promotion