aasawari.sahasrabuddhe / laravel-with-mongodb-starter-kit
A Laravel application pre-configured with MongoDB integration
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
Language:Blade
Type:project
pkg:composer/aasawari.sahasrabuddhe/laravel-with-mongodb-starter-kit
Requires
- php: ^8.2
- ext-mongodb: ^1.21|^2
- laravel/framework: ^12.0
- laravel/tinker: ^2.10.1
- mongodb/laravel-mongodb: ^5.4
Requires (Dev)
- fakerphp/faker: ^1.23
- laravel/pail: ^1.2.2
- laravel/pint: ^1.13
- laravel/sail: ^1.41
- mockery/mockery: ^1.6
- nunomaduro/collision: ^8.6
- pestphp/pest: ^3.8
- pestphp/pest-plugin-laravel: ^3.2
README
A Laravel application pre-configured with MongoDB integration, complete with authentication system and user management functionality. This starter kit provides all the necessary configurations and components to quickly build Laravel applications with MongoDB as the database.
Features
- Laravel 12 - Latest version of the Laravel framework
- MongoDB Integration - Seamless MongoDB database connection using mongodb/laravel-mongodb
- Authentication System - Complete auth flow with Laravel Breeze
- User Management - CRUD operations for user administration
- Email Verification - Built-in email verification system
- Password Reset - Secure password reset functionality
- Profile Management - User profile editing capabilities
- Pre-configured Models & Controllers - Ready-to-use User model and authentication controllers
Requirements
- PHP 8.2 or higher
- MongoDB extension (ext-mongodb)
- MongoDB server (local or cloud)
- Composer
Installation
Create a new Laravel project using this starter kit:
composer create-project mongodb-developer/laravel-with-mongodb-starter-kit my-project
cd my-project
Pre-configured Components
This starter kit comes with the following pre-configured components:
1. Database Configuration
The MongoDB connection is already configured in config/database.php:
'mongodb' => [ 'driver' => 'mongodb', 'dsn' => env('MONGODB_URI', 'mongodb://localhost:27017'), 'database' => env('MONGODB_DATABASE', 'laravel_app'), ],
2. Environment Variables
The .env.example file includes MongoDB-specific configuration:
###> mongodb/laravel-mongodb ### # DB_CONNECTION=mongodb # Format described at https://www.mongodb.com/docs/php-library/current/connect/connection-options/ # MONGODB_URI="mongodb://username:password@localhost:27017/?authSource=auth-db" # MONGODB_URI="mongodb+srv://username:password@YOUR_CLUSTER_NAME.YOUR_HASH.mongodb.net/?retryWrites=true&w=majority" # MONGODB_DATABASE="test"
3. User Model
Pre-configured User model (app/Models/User.php) with MongoDB support:
<?php namespace App\Models; use Illuminate\Auth\Authenticatable; use MongoDB\Laravel\Eloquent\Model; use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract; use Illuminate\Notifications\Notifiable; class User extends Model implements AuthenticatableContract { use Notifiable, Authenticatable; protected $connection = 'mongodb'; protected $collection = 'users'; protected $fillable = [ 'name', 'email', 'password', ]; protected $hidden = [ 'password', 'remember_token', ]; }
4. Authentication Controllers
Complete set of authentication controllers in app/Http/Controllers/Auth/:
- AuthenticatedSessionController.php- Login/logout functionality
- RegisteredUserController.php- User registration
- PasswordResetLinkController.php- Password reset links
- NewPasswordController.php- Password reset handling
- EmailVerificationPromptController.php- Email verification
- ConfirmablePasswordController.php- Password confirmation
- And more...
5. User Management Controller
UserController.php with full CRUD operations:
class UserController extends Controller { public function index() // List all users public function edit(User $user) // Show edit form public function update(Request $request, User $user) // Save changes public function destroy(User $user) // Delete user }
6. Profile Management
ProfileController.php for user profile management:
class ProfileController extends Controller { public function edit(Request $request) // Display profile form public function update(ProfileUpdateRequest $request) // Update profile public function destroy(Request $request) // Delete account }
Setup Instructions
1. Generate Application Key
php artisan key:generate
2. Configure MongoDB Connection
Update your .env file with your MongoDB connection details:
For Local MongoDB:
DB_CONNECTION=mongodb MONGODB_URI=mongodb://localhost:27017 MONGODB_DATABASE=your_database_name
For MongoDB Atlas:
DB_CONNECTION=mongodb MONGODB_URI=mongodb+srv://username:password@YOUR_CLUSTER_NAME.YOUR_HASH.mongodb.net/?retryWrites=true&w=majority MONGODB_DATABASE=your_database_name
3. Start the Development Server
php artisan serve
Available Routes
Authentication Routes
- GET /login- Login page
- POST /login- Process login
- GET /register- Registration page
- POST /register- Process registration
- POST /logout- Logout user
- GET /forgot-password- Password reset request
- POST /forgot-password- Send reset link
- GET /reset-password/{token}- Password reset form
- POST /reset-password- Process password reset
User Management Routes
- GET /users- List all users
- GET /users/{user}/edit- Edit user form
- PUT /users/{user}- Update user
- DELETE /users/{user}- Delete user
Profile Routes
- GET /profile- View profile
- PATCH /profile- Update profile
- DELETE /profile- Delete account
Features Overview
Authentication System
Complete authentication flow with:
- User registration with email verification
- Secure login with rate limiting
- Password reset functionality
- Remember me functionality
- Session management
User Management
Administrative interface for:
- Viewing all users
- Editing user information
- Deleting users
Email Features
- Email verification for new registrations
- Password reset emails
- Configurable mail settings
Security Features
- Password hashing with bcrypt
- CSRF protection
- Rate limiting on login attempts
- Secure session handling
- Input validation
What's Included
This starter kit provides:
Database Configuration - MongoDB connection ready to use
User Model - MongoDB-compatible User model with authentication
Authentication Controllers - Complete auth flow (login, register, password reset, etc.)
User Management - CRUD operations for user administration
Profile Management - User profile editing capabilities
Form Requests - Validation classes for user input
Routes - Pre-defined routes for all functionality
Security - Built-in security features and rate limiting
For learning more about integration MongoDB in Laravel applications, refer to the official Laravel Documentations.
Start building your Laravel + MongoDB-powered application!