Skip to content

codeigniter4projects/website

Repository files navigation

CodeIgniter Website

Coverage Status

This is the official website for the CodeIgniter PHP framework.

The website has been open-sourced in the interest of transparency. We welcome issues and pull requests, to handle corrections. New blog posts will not be accepted without prior authorization.

Implementation

The site has been built with CodeIgniter 4, and is meant to be an example of "good" programming style, although definitely not the only way to do things.

Some of the programming design decisions reflected:

  • The public folder is the intended document root for the webapp.
  • The architecture adheres more to the "model-view-adapter" convention, where the view is unaware of the source of data and the model is unaware of how any data might be presented. The controllers are go-betweens.
  • A "master template" lets each controller focus only with building its part of a webpage.
  • A base controller takes care of assembling finished pages, using the master template.
  • Mock data for the recent news and most recently active threads, means that the website can be tested locally, without needing access to the live forum database.
  • View fragments are used to style single "records" on their own, improving cohesion.

Resources

Server Requirements

PHP version 8.1 or higher is required, with the following extensions installed:

  • intl
  • libcurl if you plan to use the HTTP\CURLRequest library

Additionally, make sure that the following extensions are enabled in your PHP:

  • json (enabled by default - don't turn it off)
  • mbstring
  • mysqlnd
  • xml (enabled by default - don't turn it off)

Installation

Use these steps to create a local installation for development and testing.

  1. Clone the repo: git clone https://github.com/codeigniter4projects/website

  2. Work in the repo directory: cd website

  3. Make sure the writable folder is accessible: chmod -R 777 writable

  4. Install dependencies: composer install

  5. Create your .env file: cp env .env

  6. Edit .env and set at least the following:

    • GITHUB_ACCESS_TOKEN = ghp_***
      • Set your GitHub Personal Access Token.
    • CI_ENVIRONMENT = development
    • app.forceGlobalSecureRequests = false
    • database.default.database = ../writable/database.db
    • database.default.DBDriver = SQLite3
  7. Seed fake Forum data

    The website is intended to live on the same server as the forums, and uses the forum database to pull in the most recent posts. When developing locally, this poses a challenge. To make local development simpler, a migration and seed have been provided to setup a table with some mock data that can be used in place of having a local MyBB install.

    1. Migrate the database: php spark migrate -all
    2. Run the seeder: php spark db:seed ForumSeeder

At this point you should have a usable version of the current code! Try launching it locally:

  1. From the repo directory start serving the website: php spark serve
  2. In your web browser of choice navigate to the local URL: http://localhost:8080

Note The example commands above are for Linux-based systems. You may need to adjust for your operating system.

Releases

No releases published

Packages

No packages published

Languages