Skip to content

Osub/Community-Auth-For-CodeIgniter-3

Repository files navigation

Community Auth For CodeIgniter 3

This version of Community Auth is a user authentication package for CodeIgniter 3.

Website: http://community-auth.com

Server Requirements

  • CodeIgniter 3 server requirements also apply to Community Auth. Community Auth is currently developed using PHP 5.5 and PHP 7. Support for PHP versions less than 5.4 has been discontinued.
  • A MySQL database is required. Community Auth is tested on versions 5.5 and 5.6 of MySQL, and MariaDB 10.1.10.
  • A Linux or Mac operating system will allow you to take advantage of either of the installer scripts that are provided. I'm not opposed to working with somebody on some Windows installer scripts, but they don't exist as of right now.

Installation

1) Put the community_auth package in CodeIgniter's application/third_party directory.

2) Verify that extensions in community_auth/helpers and community_auth/libraries do not conflict with extensions you already have made in your application. You'll need to merge any conflicts if they exist, and then eliminate one of the files.

3) Copy files from community_auth package to CodeIgniter's application sub-directories.

  • If on linux or mac, if there is no existing application and no reason to worry about overwriting existing files, use the terminal and cd to the application directory, then execute ./third_party/community_auth/sh/.install.sh, then skip to step 8. You will probably need to set permissions of .install.sh to allow execution. After execution, remove permissions to execute or remove the file completely.
  • If not on linux or mac, or if you already have an existing application, proceed to step 4.

4) Copy MY_Controller.php, MY_Input.php, and MY_Model.php from community_auth/core to CodeIgniter's application/core directory. If you already had these files, merge them with your existing files.

5) Copy auth_constants.php and auth_sess_check.php from community_auth/hooks to CodeIgniter's application/hooks directory.

6) Copy the Examples and Key_creator controllers to CodeIgniter's application/controllers directory.

7) The .htaccess file in community_auth/public_root can be moved to CodeIgniter's public root directory. Notice the lines at the top that allow for access denial. If you already have an .htaccess file, make sure to include those lines at the top of it.

8) If the site has a security certificate, change value of USE_SSL to 1 in application/hooks/auth_constants.php. While you are there you should review the other constants, as all are configurable.

9) Modify config/autoload:

$autoload['packages'] = array(
	APPPATH . 'third_party/community_auth/'
);

$autoload['libraries'] = array(
	'database','session','tokens','Authentication'
);

$autoload['helper'] = array(
	'serialization','cookie'
);

$autoload['config'] = array(
	'db_tables','authentication'
);

$autoload['model'] = array(
	'auth_model'
);

10) Add route to login page in config/routes:

$route[LOGIN_PAGE] = 'examples/login';

11) Define Community Auth hooks by adding them to config/hooks.

$hook['pre_system'] = array(
	'function' => 'auth_constants',
	'filename' => 'auth_constants.php',
	'filepath' => 'hooks'
);
$hook['post_system'] = array(
	'function' => 'auth_sess_check',
	'filename' => 'auth_sess_check.php',
	'filepath' => 'hooks'
);

12) While not critical for basic Community Auth usage, check out and configure community_auth/config/authentication.php as needed.

13) Database

  • Create a database if not already available.
  • Run the SQL located in community_auth/sql/install.sql.
  • Configure CodeIgniter to use the database in config/database.php.

14) Enable hooks and make sure there is an encryption key set in config/config.php. To quickly create an encryption key, load the index method of the Key_creator controller.

15) Create a user for testing purposes by editing the user_data array that is inside the create_user method, which is in the Examples controller. When specifying a user level, be aware of the "levels_and_roles" array located in config/authentication. In order to login in the next step the user level must be set to 9, which by default is an admin. Also note that this method of user creation does not account for password strength, yet the login validation does. A password that is strong enough will have an uppercase letter, a number, and be at least 8 characters long. To create the user, request the examples/create_user URI in your browser:

  • /index.php/examples/create_user if you are not using mod_rewrite to remove index.php.
  • /examples/create_user if you are using mod_rewrite to remove index.php.

16) If you did everything right, you should be able to go to the examples/index URI and login with the user you just created:

  • /index.php/examples if you are not using mod_rewrite to remove index.php.
  • /examples if you are using mod_rewrite to remove index.php.

17) Loging out is as follows:

  • /index.php/examples/logout if you are not using mod_rewrite to remove index.php.
  • /examples/logout if you are using mod_rewrite to remove index.php.

License

Community Auth is distributed with a Revised "3-clause" BSD license, http://www.opensource.org/licenses/BSD-3-Clause:

Copyright (c) 2011 - 2016, Robert B Gottier. All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

  3. Neither the name "Community Auth", nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.