Skip to content

Latest commit

 

History

History
105 lines (70 loc) · 4.08 KB

README.md

File metadata and controls

105 lines (70 loc) · 4.08 KB

cloudinary-for-codeigniter

This repo demonstrates how to integrate the latest Cloudinary API PHP library into CodeIgniter 3 using a dummy library.

This dummy library technique can be used to get around CodeIgniter 3's issues with loading libraries dependent on namespaces like Cloudinary's.

This project is still very much in development | Master branch is the main branch. / Dev branch is the working branch.

Integrate Cloudinary PHP API Library into CodeIgniter

  1. Clone this project (if you haven't already)

  2. In the CodeIgniter "application/libraries" folder, put your "cloudinary" folder (containing the Cloudinary PHP API library) and the file called Cloudinarylib.php (located in the "cloudinary-for-codeigniter" folder).

  3. Open the "Cloudinarylib.php" file and replace the placeholder API connect info with your actual API connect info:

<?php
defined('BASEPATH') OR exit('No direct script access allowed');

// setup the dummy class for Cloudinary
class Cloudinarylib {

    public function __construct()
    {

        // include the cloudinary library within the dummy class
        require('cloudinary/src/Cloudinary.php');
        require 'cloudinary/src/Uploader.php';
        require 'cloudinary/src/Api.php';

        \Cloudinary::config(array(
            "cloud_name" => "your_cloud_name",
            "api_key" => "your_api_key", /*874837483274837*/
            "api_secret" => "your_api_secret" /* a676b67565c6767a6767d6767f676fe1 */
        ));
    }
}

Using The Cloudinary Library Within CodeIgniter

  1. Once the above steps are completed, your Cloudinary API library will be availabe via the "cloudinarylib" name and can be loaded like any other CodeIgniter library.

Below is from the CodeIgniter sample site within the Example folder which uses the standard welcome page controller and the "sample" image from Cloudinary:

*** Note: The Cloudinarylib.php file and cloudinary folder have already been placed in example site***

	<?php
defined('BASEPATH') OR exit('No direct script access allowed');

class Welcome extends CI_Controller {

	public function __construct()
		{
			parent::__construct();

			// load the cloudinary dummy library
			$this->load->library('cloudinarylib');
		}

	public function index()
	{

		// execute cloudinary api call to grab sample image and assign to $image variable in the view
		$data['image'] = cl_image_tag("sample.jpg", array( "alt" => "Sample Image" ));

        /* The rest of the Cloudinary library is available using it's namespace "\Cloudinary\"
        To see it in action, uncomment code line below and replace "url_to_image" with an image url
        and when the welcome page loads it will upload to your Cloudinary account and return a response object
        in the $data['imageupload'] array.

        -- See Cloudinary PHP API docs for additional examples.
        */

        //$data['imageupload'] = \Cloudinary\Uploader::upload("https://kojiflowers.com/wp-content/uploads/2017/01/vide-1050x478.png");

		$this->load->view('welcome_message',$data);
	}
}

In your welcome_page view, echo the variable like you normally would to display the image:

<?php echo $image; ?>

If done correctly, you should see an image popup at the bottom of your welcome page.

Using the rest of the Cloudinary API...

As for the rest of the library, now you can access it by using the "\Cloudinary" namespace in whichever class you have loaded the Cloudinary library (note: this is currently how Cloudinary's examples use the PHP API).

$data['imageupload'] = \Cloudinary\Uploader::upload("https://kojiflowers.com/wp-content/uploads/2017/01/vide-1050x478.png");
        

In the above example the upload would be executed on page load and the result object would be available in the view via the $imageupload variable.

Additional Info

Feel free to fork this project and make some cool stuff with it. It is still early stage but I welcome help from the dev community.

For updates and/or other stuff to check out, visit my blog or follow me on Twitter: @KojiFlowers.