Wednesday, September 24, 2014

Create a simple blog using Laravel 4

Creating a Blog Using Laravel 4 Part 1
Laravel 4 Blog Tutorial Screenshot
In this article we will create a simple blog using Laravel 4. Our blog application will have the following features:
  • Display posts with read more links on home page.
  • Users will able to search posts on blog.
  • Display single post with comments.
  • Allow users to post comments.
  • Administrator will be able to perform CRUD operations on posts and comments.
  • Administrator will be able to moderate comments.

Laravel Quick Installation and Setup

I will assume that you have a working installation of Laravel 4. Otherwise, you can follow these steps to install and setup Laravel 4:
  • Install Laravel 4 by following instructions provided here.
  • Create a database using the MySQL terminal client:
    ┌─[usm4n@usm4n-desktop]―[~]
    └─•mysql -u root -p
    Enter password: 
    mysql> create database laravel;
    Query OK, 1 row affected (0.00 sec)
  • Configure database in /app/config/database.php:
    1. 'mysql' => array(
    2. 'driver' => 'mysql',
    3. 'host' => 'localhost',
    4. 'database' => 'laravel',
    5. 'username' => 'root',
    6. 'password' => 'very_secret_password',
    7. 'charset' => 'utf8',
    8. 'collation' => 'utf8_unicode_ci',
    9. 'prefix' => '',
    10. ),

Creating Database Migrations

In this section, we will create database tables for our blog application using Laravel Database Migrations. Our application will be utilizing posts and comments tables to store articles and user comments respectively. (Read more on migrations here)
QUICK TIP:
We use artisan migrate:make create_tablename_table and artisan migrate commands to create and run migrations respectively.
Migration class for posts table:
  1. <?php
  2. use Illuminate\Database\Migrations\Migration;
  3. use Illuminate\Database\Schema\Blueprint;
  4.  
  5. class CreatePostsTable extends Migration {
  6.  
  7. /**
  8. * Run the migrations.
  9. *
  10. * @return void
  11. */
  12. public function up()
  13. {
  14. Schema::create('posts', function(Blueprint $table) {
  15. $table->increments('id');
  16. $table->string('title');
  17. $table->string('read_more');
  18. $table->text('content');
  19. $table->unsignedInteger('comment_count');
  20. $table->timestamps();
  21. $table->engine = 'MyISAM';
  22. });
  23. DB::statement('ALTER TABLE posts ADD FULLTEXT search(title, content)');
  24. }
  25. /**
  26. * Reverse the migrations.
  27. *
  28. * @return void
  29. */
  30. public function down()
  31. {
  32. Schema::table('posts', function(Blueprint $table) {
  33. $table->dropIndex('search');
  34. $table->drop();
  35. });
  36. }
  37. }
Note that, I have used $table->engine='MyISAM' and added a composite fulltext index usingtitle and content columns. This will allow us to utilize MySQL fulltext search on posts table.
Code for comments table migration:
  1. <?php
  2.  
  3. use Illuminate\Database\Migrations\Migration;
  4. use Illuminate\Database\Schema\Blueprint;
  5.  
  6. class CreateCommentsTable extends Migration {
  7.  
  8. /**
  9. * Run the migrations.
  10. *
  11. * @return void
  12. */
  13. public function up()
  14. {
  15. Schema::create('comments', function(Blueprint $table) {
  16. $table->increments('id');
  17. $table->unsignedInteger('post_id');
  18. $table->string('commenter');
  19. $table->string('email');
  20. $table->text('comment');
  21. $table->boolean('approved');
  22. $table->timestamps();
  23. });
  24. }
  25. /**
  26. * Reverse the migrations.
  27. *
  28. * @return void
  29. */
  30. public function down()
  31. {
  32. Schema::drop('comments');
  33. }
  34.  
  35. }
The post_id field will help us in defining one to many relationship using Eloquent ORM seamlessly. We will use approved field of comments table for comments moderation purpose. We will cover the users table in Authentication Section.

Creating Models Using Eloquent ORM

The Eloquent ORM included with Laravel provides a beautiful, simple ActiveRecord implementation for working with your database. Each database table has a corresponding “Model” which is used to interact with that table.Laravel Eloquent ORM Documentation
We use singular variants of table names as our Eloqent Model names, this convention helps the Eloquent to figure out the table to be used with a particular Model. For instance: if the name of the Model is Post Eloquent will assume a table with name posts to be used.
Here is the code for our Post and Comment Models:
  1. <?php
  2. // file: app/models/Post.php
  3. class Post extends Eloquent {
  4.  
  5. public function comments()
  6. {
  7. return $this->hasMany('Comment');
  8. }
  9.  
  10. }
  11. // file: app/models/Comment.php
  12. class Comment extends Eloquent {
  13.  
  14. public function post()
  15. {
  16. return $this->belongsTo('Post');
  17. }
  18. }

Seeding Database Tables

We will use a single PostCommentSeeder class to populate both posts and comments tables.
QUICK TIP:
We use artisan db:seed command to seed the database.
Code for PostCommentSeeder:
  1.  <?php
  2.  
  3. class PostCommentSeeder extends Seeder {
  4.  
  5. public function run()
  6. {
  7. $content = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.
  8. Praesent vel ligula scelerisque, vehicula dui eu, fermentum velit.
  9. Phasellus ac ornare eros, quis malesuada augue. Nunc ac nibh at mauris dapibus fermentum.
  10. In in aliquet nisi, ut scelerisque arcu. Integer tempor, nunc ac lacinia cursus,
  11. mauris justo volutpat elit,
  12. eget accumsan nulla nisi ut nisi. Etiam non convallis ligula. Nulla urna augue,
  13. dignissim ac semper in, ornare ac mauris. Duis nec felis mauris.';
  14. for( $i = 1 ; $i <= 20 ; $i++ )
  15. {
  16. $post = new Post;
  17. $post->title = "Post no $i";
  18. $post->read_more = substr($content, 0, 120);
  19. $post->content = $content;
  20. $post->save();
  21.  
  22. $maxComments = mt_rand(3,15);
  23. for( $j = 1 ; $j <= $maxComments; $j++)
  24. {
  25. $comment = new Comment;
  26. $comment->commenter = 'xyz';
  27. $comment->comment = substr($content, 0, 120);
  28. $comment->email = 'xyz@xmail.com';
  29. $comment->approved = 1;
  30. $post->comments()->save($comment);
  31. $post->increment('comment_count');
  32. }
  33. }
  34. }
  35. }
The outer for loop creates a new Post Model on each iteration and saves it after setting the properties: titleread_morecontent. The inner loop creates random number of comments for each Post and increments the comment_count in posts table.

The ‘artisan tinker’ Command

The Artisan CLI tool provides us with an easy way to interact with Laravel application from command line. We use artisan tinker command to use the interactive shell. Let’s practice some Eloquent queries on our test data.
┌─[usm4n@usm4n-desktop]―[~]
└─•artisan tinker
>

Find By Id Using find()

>$post = Post::find(2);
>$post->setHidden(['content','read_more','updated_at']);
>echo $post;
{"id":"2","title":"Post no 2","comment_count":"7","created_at":"2014-01-06 09:43:44"}

Limit No Of Records Using take() And skip()

>$post = Post::skip(5)->take(2)->get();
>foreach($post as $value) echo "post id:$value->id ";
post id:6 post id:7

Using select() And first()

>$post = Post::select('id','title')->first();
>echo $post;
{"id":"1","title":"Post no 1"}

Using where() With select()

>$post = Post::select('id','title')->where('id','=',10)->first();
>echo $post;
{"id":"10","title":"Post no 10"}

Getting Related Records Using Dynamic Property

>$post = Post::find(4);
>echo $post->comments[0]->commenter;
xyz

Getting Parent Records From Child Model

>$comment = Comment::find(1);
>echo $comment->post->title;
Post no 1
For a complete reference on Eloquent ORM queries visit official Eloquent Documentation Page.
That’s all for now. Thanks and Regards!

Tuesday, July 22, 2014

An Introduction about Laravel Framework

Introduction
Laravel is a very powerful framework, designed for php web application. It will give you ways to modularize your codes and make them look cleaner and easier to read and understand. It is open source software under MIT License.

Features :

Now, we will talk about some prominent features of this framework which make it different from other :
Bundles : These are small packages which you may download to add certain functionality to your web application. Hence, saving a lot of coding stuff and time. These may be containing some custom functionality.
Class Autoloading: It assure that correct components are loaded at correct time and saves a lot of your headache.
View Composer : Theses are block of codes which can run when view is loaded.
Unit testing: Laravel allows user to easily create unit test and run these test making use of Artisan utility.The best thing is it itself supports a number of test to ensure application stability.
The Eloquent ORM: The Eloquent ORM is the most advanced PHP ActiveRecord implementation available. With the capacity to easily apply constraints to both relationships and nested eager-loading you'll have complete control over your data with all of the conveniences of ActiveRecord.
Application Logic : can be implemented within your application either using controllers or directly into route declarations.
Reverse Routing : allows you to create links to named routes. When creating links just use the route's name and Laravel will automatically insert the correct URI. This allows you to change your routes at a later time and Laravel will update all of the relevant links site-wide.
Restful Controllers: are an optional way to separate your GET and POST request logic. In a login example your controller's get_login() action would serve up the form and your controller's post_login() action would accept the posted form, validate, and either redirect to the login form with an error message or redirect your user to their dashboard.
The IoC container (Inversion of Control): Inversion of Control gives you a method for generating new objects and optionally instantiating and referencing singletons. IoC means that you'll rarely ever need to bootstrap any external libraries. It also means that you can access these objects from anywhere in your code without needing to deal with an inflexible monolithic structure.

Installation and Setup of Laravel

Requirements:

  • Apache or any other compatible web server
  • Since, Laravel makes use of PHP 5.3 features so it’s also requirement.
  • For detecting file Mime type Laravel make use of FileInfo Library. Windows users must enable this by making appropriate changes(include the bundled php_fileinfo.dll DLL file in php.ini) to include this extension.
  • It make use of Mcrypt library for security purposes. This library is mostly preinstalled but if you have problems in finding this, then check the vendor site of your LAMP installation

Installation

  • Download Laravel from http://laravel.com/download
  • Extract the Laravel archive and upload the contents to your web server.
  • Set the value of the key option in the config/application.php file to a random, 32 character string.
  • Verify that the storage/views directory is writable.
  • Navigate to your application in a web browser.
Personally, I used Wamp server which included everything needed. This made every requirements fulfillment too easy. You can directly include extensions by making use of GUI.
If everything is fine you must see a welcome page like below :
Welcome Page
Figure 1: Welcome Page

Server Configuration

Laravel tends to protect your codes, bundles by keeping only those files that are necessarily public in the web server's DocumentRoot. This prevents server misconfiguration from getting your codes leaked or accessible to third party.

Basic configuration

All of the configurations provided are located in your applications config/ directory.Make sure you change the 32 character key inside the application.php inside the config folder. Make the key as any random 32 character string. You may automatically generate key making use of Artisan command utility, which we will discuss later.

Environment

Its most likely that the configuration you set for local environment is not same as production. Laravel default environment handling mechanism is URL based, which will make setting up environments very easy. If you open the paths.php from your Laravel installation root directory, you will see the below:
Listing 1: Paths.php
$environments = array(

    'local' => array('http://localhost*', '*.dev'),

);
Here, all the url which are starting with localhost and ending with.dev will be considered under local environment. Now if you create a directory local inside application/config then it will override the options in the base application/config directory. You may create as many environment as you like.

Key terms

Here are some key term which you must be knowing :
Models : Models are the heart of your application. It mainly consist of Business Logic. The models mainly comprises of Database interactions, File I/O operations ,Interacting with web services etc.
Libraries : Libraries are classes that perform tasks that aren't specific to your application. For example a library which can convert your table data to graphs and show that. Creating library is too easy. For eg we create a ShowMess.php with following content and place this inside the library folder:
Listing 2: Library
 
<?php

class ShowMess {

    public static function write($text) {
        echo $text;
    }
}

Now we can call ShowMess::write(“Displaying of text making use of library. This is too simple and easy”) from anywhere in our application which will print “Displaying of text making use of library. This is too simple and easy”.
With Laravel Auto loading feature it is very easy to use both Models and Library.

Troubleshooting

In case of installation problems please check the below points:
  • Make sure the public directory is document root of your web server.
  • If you are using mod_rewrite, set the index option in application/config/application.php to an empty string.
  • Verify that your storage folder and the folders within are writable by your web server.
This is all about an introduction to Laravel. In coming tutorials we will learn a lot about making use of this exciting framework in our web application. Hope you liked the article, see you next time with some more informational article.