commit
10412ab7f6
486 changed files with 123242 additions and 0 deletions
@ -0,0 +1,21 @@ |
|||||
|
MIT License |
||||
|
|
||||
|
Copyright (c) <year> <copyright holders> |
||||
|
|
||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||
|
of this software and associated documentation files (the "Software"), to deal |
||||
|
in the Software without restriction, including without limitation the rights |
||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||
|
copies of the Software, and to permit persons to whom the Software is furnished |
||||
|
to do so, subject to the following conditions: |
||||
|
|
||||
|
The above copyright notice and this permission notice (including the next |
||||
|
paragraph) shall be included in all copies or substantial portions of the |
||||
|
Software. |
||||
|
|
||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS |
||||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS |
||||
|
OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
||||
|
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF |
||||
|
OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
@ -0,0 +1,19 @@ |
|||||
|
# RPSLS |
||||
|
|
||||
|
Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
|
||||
|
|
||||
|
----- |
||||
|
|
||||
|
As Sheldon explains: |
||||
|
|
||||
|
* Rock crushes lizard |
||||
|
* Rock crushes scissors |
||||
|
* Paper covers rock |
||||
|
* Paper disproves Spock |
||||
|
* Scissors cuts paper |
||||
|
* Scissors decapitates lizard |
||||
|
* Lizard poisons Spock |
||||
|
* Lizard eats paper |
||||
|
* Spock smashes scissors |
||||
|
* Spock vaporizes rock |
@ -0,0 +1,6 @@ |
|||||
|
<IfModule authz_core_module> |
||||
|
Require all denied |
||||
|
</IfModule> |
||||
|
<IfModule !authz_core_module> |
||||
|
Deny from all |
||||
|
</IfModule> |
@ -0,0 +1,15 @@ |
|||||
|
<?php |
||||
|
|
||||
|
/** |
||||
|
* The goal of this file is to allow developers a location |
||||
|
* where they can overwrite core procedural functions and |
||||
|
* replace them with their own. This file is loaded during |
||||
|
* the bootstrap process and is called during the frameworks |
||||
|
* execution. |
||||
|
* |
||||
|
* This can be looked at as a `master helper` file that is |
||||
|
* loaded early on, and may also contain additional functions |
||||
|
* that you'd like to use throughout your entire application |
||||
|
* |
||||
|
* @link: https://codeigniter4.github.io/CodeIgniter4/ |
||||
|
*/ |
@ -0,0 +1,269 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class App extends BaseConfig |
||||
|
{ |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Base Site URL |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| URL to your CodeIgniter root. Typically this will be your base URL, |
||||
|
| WITH a trailing slash: |
||||
|
| |
||||
|
| http://example.com/ |
||||
|
| |
||||
|
| If this is not set then CodeIgniter will try guess the protocol, domain |
||||
|
| and path to your installation. However, you should always configure this |
||||
|
| explicitly and never rely on auto-guessing, especially in production |
||||
|
| environments. |
||||
|
| |
||||
|
*/ |
||||
|
public $baseURL = 'https://rpsls.rhays.us'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Index File |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Typically this will be your index.php file, unless you've renamed it to |
||||
|
| something else. If you are using mod_rewrite to remove the page set this |
||||
|
| variable so that it is blank. |
||||
|
| |
||||
|
*/ |
||||
|
public $indexPage = ''; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| URI PROTOCOL |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This item determines which getServer global should be used to retrieve the |
||||
|
| URI string. The default setting of 'REQUEST_URI' works for most servers. |
||||
|
| If your links do not seem to work, try one of the other delicious flavors: |
||||
|
| |
||||
|
| 'REQUEST_URI' Uses $_SERVER['REQUEST_URI'] |
||||
|
| 'QUERY_STRING' Uses $_SERVER['QUERY_STRING'] |
||||
|
| 'PATH_INFO' Uses $_SERVER['PATH_INFO'] |
||||
|
| |
||||
|
| WARNING: If you set this to 'PATH_INFO', URIs will always be URL-decoded! |
||||
|
*/ |
||||
|
public $uriProtocol = 'REQUEST_URI'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Default Locale |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The Locale roughly represents the language and location that your visitor |
||||
|
| is viewing the site from. It affects the language strings and other |
||||
|
| strings (like currency markers, numbers, etc), that your program |
||||
|
| should run under for this request. |
||||
|
| |
||||
|
*/ |
||||
|
public $defaultLocale = 'en'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Negotiate Locale |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If true, the current Request object will automatically determine the |
||||
|
| language to use based on the value of the Accept-Language header. |
||||
|
| |
||||
|
| If false, no automatic detection will be performed. |
||||
|
| |
||||
|
*/ |
||||
|
public $negotiateLocale = false; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Supported Locales |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If $negotiateLocale is true, this array lists the locales supported |
||||
|
| by the application in descending order of priority. If no match is |
||||
|
| found, the first locale will be used. |
||||
|
| |
||||
|
*/ |
||||
|
public $supportedLocales = ['en']; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Application Timezone |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The default timezone that will be used in your application to display |
||||
|
| dates with the date helper, and can be retrieved through app_timezone() |
||||
|
| |
||||
|
*/ |
||||
|
public $appTimezone = 'America/Chicago'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Default Character Set |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This determines which character set is used by default in various methods |
||||
|
| that require a character set to be provided. |
||||
|
| |
||||
|
| See http://php.net/htmlspecialchars for a list of supported charsets. |
||||
|
| |
||||
|
*/ |
||||
|
public $charset = 'UTF-8'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| URI PROTOCOL |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If true, this will force every request made to this application to be |
||||
|
| made via a secure connection (HTTPS). If the incoming request is not |
||||
|
| secure, the user will be redirected to a secure version of the page |
||||
|
| and the HTTP Strict Transport Security header will be set. |
||||
|
*/ |
||||
|
public $forceGlobalSecureRequests = false; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Session Variables |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| 'sessionDriver' |
||||
|
| |
||||
|
| The storage driver to use: files, database, redis, memcached |
||||
|
| - CodeIgniter\Session\Handlers\FileHandler |
||||
|
| - CodeIgniter\Session\Handlers\DatabaseHandler |
||||
|
| - CodeIgniter\Session\Handlers\MemcachedHandler |
||||
|
| - CodeIgniter\Session\Handlers\RedisHandler |
||||
|
| |
||||
|
| 'sessionCookieName' |
||||
|
| |
||||
|
| The session cookie name, must contain only [0-9a-z_-] characters |
||||
|
| |
||||
|
| 'sessionExpiration' |
||||
|
| |
||||
|
| The number of SECONDS you want the session to last. |
||||
|
| Setting to 0 (zero) means expire when the browser is closed. |
||||
|
| |
||||
|
| 'sessionSavePath' |
||||
|
| |
||||
|
| The location to save sessions to, driver dependent. |
||||
|
| |
||||
|
| For the 'files' driver, it's a path to a writable directory. |
||||
|
| WARNING: Only absolute paths are supported! |
||||
|
| |
||||
|
| For the 'database' driver, it's a table name. |
||||
|
| Please read up the manual for the format with other session drivers. |
||||
|
| |
||||
|
| IMPORTANT: You are REQUIRED to set a valid save path! |
||||
|
| |
||||
|
| 'sessionMatchIP' |
||||
|
| |
||||
|
| Whether to match the user's IP address when reading the session data. |
||||
|
| |
||||
|
| WARNING: If you're using the database driver, don't forget to update |
||||
|
| your session table's PRIMARY KEY when changing this setting. |
||||
|
| |
||||
|
| 'sessionTimeToUpdate' |
||||
|
| |
||||
|
| How many seconds between CI regenerating the session ID. |
||||
|
| |
||||
|
| 'sessionRegenerateDestroy' |
||||
|
| |
||||
|
| Whether to destroy session data associated with the old session ID |
||||
|
| when auto-regenerating the session ID. When set to FALSE, the data |
||||
|
| will be later deleted by the garbage collector. |
||||
|
| |
||||
|
| Other session cookie settings are shared with the rest of the application, |
||||
|
| except for 'cookie_prefix' and 'cookie_httponly', which are ignored here. |
||||
|
| |
||||
|
*/ |
||||
|
public $sessionDriver = 'CodeIgniter\Session\Handlers\FileHandler'; |
||||
|
public $sessionCookieName = 'ci_session'; |
||||
|
public $sessionExpiration = 3600; |
||||
|
public $sessionSavePath = WRITEPATH . 'session'; |
||||
|
public $sessionMatchIP = false; |
||||
|
public $sessionTimeToUpdate = 300; |
||||
|
public $sessionRegenerateDestroy = false; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Cookie Related Variables |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| 'cookiePrefix' = Set a cookie name prefix if you need to avoid collisions |
||||
|
| 'cookieDomain' = Set to .your-domain.com for site-wide cookies |
||||
|
| 'cookiePath' = Typically will be a forward slash |
||||
|
| 'cookieSecure' = Cookie will only be set if a secure HTTPS connection exists. |
||||
|
| 'cookieHTTPOnly' = Cookie will only be accessible via HTTP(S) (no javascript) |
||||
|
| |
||||
|
| Note: These settings (with the exception of 'cookie_prefix' and |
||||
|
| 'cookie_httponly') will also affect sessions. |
||||
|
| |
||||
|
*/ |
||||
|
public $cookiePrefix = ''; |
||||
|
public $cookieDomain = ''; |
||||
|
public $cookiePath = '/'; |
||||
|
public $cookieSecure = false; |
||||
|
public $cookieHTTPOnly = false; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Reverse Proxy IPs |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If your server is behind a reverse proxy, you must whitelist the proxy |
||||
|
| IP addresses from which CodeIgniter should trust headers such as |
||||
|
| HTTP_X_FORWARDED_FOR and HTTP_CLIENT_IP in order to properly identify |
||||
|
| the visitor's IP address. |
||||
|
| |
||||
|
| You can use both an array or a comma-separated list of proxy addresses, |
||||
|
| as well as specifying whole subnets. Here are a few examples: |
||||
|
| |
||||
|
| Comma-separated: '10.0.1.200,192.168.5.0/24' |
||||
|
| Array: array('10.0.1.200', '192.168.5.0/24') |
||||
|
*/ |
||||
|
public $proxyIPs = '192.168.1.0/24'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Cross Site Request Forgery |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Enables a CSRF cookie token to be set. When set to TRUE, token will be |
||||
|
| checked on a submitted form. If you are accepting user data, it is strongly |
||||
|
| recommended CSRF protection be enabled. |
||||
|
| |
||||
|
| CSRFTokenName = The token name |
||||
|
| CSRFHeaderName = The header name |
||||
|
| CSRFCookieName = The cookie name |
||||
|
| CSRFExpire = The number in seconds the token should expire. |
||||
|
| CSRFRegenerate = Regenerate token on every submission |
||||
|
| CSRFRedirect = Redirect to previous page with error on failure |
||||
|
*/ |
||||
|
public $CSRFTokenName = 'csrf_test_name'; |
||||
|
public $CSRFHeaderName = 'X-CSRF-TOKEN'; |
||||
|
public $CSRFCookieName = 'csrf_cookie_name'; |
||||
|
public $CSRFExpire = 7200; |
||||
|
public $CSRFRegenerate = true; |
||||
|
public $CSRFRedirect = true; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Content Security Policy |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Enables the Response's Content Secure Policy to restrict the sources that |
||||
|
| can be used for images, scripts, CSS files, audio, video, etc. If enabled, |
||||
|
| the Response object will populate default values for the policy from the |
||||
|
| ContentSecurityPolicy.php file. Controllers can always add to those |
||||
|
| restrictions at run time. |
||||
|
| |
||||
|
| For a better understanding of CSP, see these documents: |
||||
|
| - http://www.html5rocks.com/en/tutorials/security/content-security-policy/ |
||||
|
| - http://www.w3.org/TR/CSP/ |
||||
|
*/ |
||||
|
public $CSPEnabled = false; |
||||
|
|
||||
|
} |
@ -0,0 +1,88 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
require_once SYSTEMPATH . 'Config/AutoloadConfig.php'; |
||||
|
|
||||
|
/** |
||||
|
* ------------------------------------------------------------------- |
||||
|
* AUTO-LOADER |
||||
|
* ------------------------------------------------------------------- |
||||
|
* This file defines the namespaces and class maps so the Autoloader |
||||
|
* can find the files as needed. |
||||
|
*/ |
||||
|
class Autoload extends \CodeIgniter\Config\AutoloadConfig |
||||
|
{ |
||||
|
public $psr4 = []; |
||||
|
|
||||
|
public $classmap = []; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
/** |
||||
|
* Collects the application-specific autoload settings and merges |
||||
|
* them with the framework's required settings. |
||||
|
* |
||||
|
* NOTE: If you use an identical key in $psr4 or $classmap, then |
||||
|
* the values in this file will overwrite the framework's values. |
||||
|
*/ |
||||
|
public function __construct() |
||||
|
{ |
||||
|
parent::__construct(); |
||||
|
|
||||
|
/** |
||||
|
* ------------------------------------------------------------------- |
||||
|
* Namespaces |
||||
|
* ------------------------------------------------------------------- |
||||
|
* This maps the locations of any namespaces in your application |
||||
|
* to their location on the file system. These are used by the |
||||
|
* Autoloader to locate files the first time they have been instantiated. |
||||
|
* |
||||
|
* The '/app' and '/system' directories are already mapped for |
||||
|
* you. You may change the name of the 'App' namespace if you wish, |
||||
|
* but this should be done prior to creating any namespaced classes, |
||||
|
* else you will need to modify all of those classes for this to work. |
||||
|
* |
||||
|
* DO NOT change the name of the CodeIgniter namespace or your application |
||||
|
* WILL break. * |
||||
|
* Prototype: |
||||
|
* |
||||
|
* $Config['psr4'] = [ |
||||
|
* 'CodeIgniter' => SYSPATH |
||||
|
* `]; |
||||
|
*/ |
||||
|
$psr4 = [ |
||||
|
'Config' => APPPATH . 'Config', |
||||
|
APP_NAMESPACE => APPPATH, // For custom namespace |
||||
|
'App' => APPPATH, // To ensure filters, etc still found, |
||||
|
]; |
||||
|
|
||||
|
/** |
||||
|
* ------------------------------------------------------------------- |
||||
|
* Class Map |
||||
|
* ------------------------------------------------------------------- |
||||
|
* The class map provides a map of class names and their exact |
||||
|
* location on the drive. Classes loaded in this manner will have |
||||
|
* slightly faster performance because they will not have to be |
||||
|
* searched for within one or more directories as they would if they |
||||
|
* were being autoloaded through a namespace. |
||||
|
* |
||||
|
* Prototype: |
||||
|
* |
||||
|
* $Config['classmap'] = [ |
||||
|
* 'MyClass' => '/path/to/class/file.php' |
||||
|
* ]; |
||||
|
*/ |
||||
|
$classmap = []; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
// Do Not Edit Below This Line |
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
$this->psr4 = array_merge($this->psr4, $psr4); |
||||
|
$this->classmap = array_merge($this->classmap, $classmap); |
||||
|
|
||||
|
unset($psr4, $classmap); |
||||
|
} |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
} |
@ -0,0 +1,32 @@ |
|||||
|
<?php |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| ERROR DISPLAY |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| In development, we want to show as many errors as possible to help |
||||
|
| make sure they don't make it to production. And save us hours of |
||||
|
| painful debugging. |
||||
|
*/ |
||||
|
error_reporting(-1); |
||||
|
ini_set('display_errors', '1'); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DEBUG BACKTRACES |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| If true, this constant will tell the error screens to display debug |
||||
|
| backtraces along with the other error information. If you would |
||||
|
| prefer to not see this, set this value to false. |
||||
|
*/ |
||||
|
defined('SHOW_DEBUG_BACKTRACE') || define('SHOW_DEBUG_BACKTRACE', true); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DEBUG MODE |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Debug mode is an experimental flag that can allow changes throughout |
||||
|
| the system. This will control whether Kint is loaded, and a few other |
||||
|
| items. It can always be used within your own application too. |
||||
|
*/ |
||||
|
|
||||
|
defined('CI_DEBUG') || define('CI_DEBUG', 1); |
@ -0,0 +1,22 @@ |
|||||
|
<?php |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| ERROR DISPLAY |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Don't show ANY in production environments. Instead, let the system catch |
||||
|
| it and display a generic error message. |
||||
|
*/ |
||||
|
ini_set('display_errors', '0'); |
||||
|
error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED & ~E_STRICT & ~E_USER_NOTICE & ~E_USER_DEPRECATED); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DEBUG MODE |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Debug mode is an experimental flag that can allow changes throughout |
||||
|
| the system. It's not widely used currently, and may not survive |
||||
|
| release of the framework. |
||||
|
*/ |
||||
|
|
||||
|
defined('CI_DEBUG') || define('CI_DEBUG', 0); |
@ -0,0 +1,33 @@ |
|||||
|
<?php |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| ERROR DISPLAY |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| In development, we want to show as many errors as possible to help |
||||
|
| make sure they don't make it to production. And save us hours of |
||||
|
| painful debugging. |
||||
|
*/ |
||||
|
error_reporting(-1); |
||||
|
ini_set('display_errors', '1'); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DEBUG BACKTRACES |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| If true, this constant will tell the error screens to display debug |
||||
|
| backtraces along with the other error information. If you would |
||||
|
| prefer to not see this, set this value to false. |
||||
|
*/ |
||||
|
defined('SHOW_DEBUG_BACKTRACE') || define('SHOW_DEBUG_BACKTRACE', true); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DEBUG MODE |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Debug mode is an experimental flag that can allow changes throughout |
||||
|
| the system. It's not widely used currently, and may not survive |
||||
|
| release of the framework. |
||||
|
*/ |
||||
|
|
||||
|
defined('CI_DEBUG') || define('CI_DEBUG', 1); |
@ -0,0 +1,120 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Cache extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Primary Handler |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The name of the preferred handler that should be used. If for some reason |
||||
|
| it is not available, the $backupHandler will be used in its place. |
||||
|
| |
||||
|
*/ |
||||
|
public $handler = 'file'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Backup Handler |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The name of the handler that will be used in case the first one is |
||||
|
| unreachable. Often, 'file' is used here since the filesystem is |
||||
|
| always available, though that's not always practical for the app. |
||||
|
| |
||||
|
*/ |
||||
|
public $backupHandler = 'dummy'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Cache Directory Path |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The path to where cache files should be stored, if using a file-based |
||||
|
| system. |
||||
|
| |
||||
|
*/ |
||||
|
public $storePath = WRITEPATH . 'cache/'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Cache Include Query String |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Whether to take the URL query string into consideration when generating |
||||
|
| output cache files. Valid options are: |
||||
|
| |
||||
|
| false = Disabled |
||||
|
| true = Enabled, take all query parameters into account. |
||||
|
| Please be aware that this may result in numerous cache |
||||
|
| files generated for the same page over and over again. |
||||
|
| array('q') = Enabled, but only take into account the specified list |
||||
|
| of query parameters. |
||||
|
| |
||||
|
*/ |
||||
|
public $cacheQueryString = false; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Key Prefix |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This string is added to all cache item names to help avoid collisions |
||||
|
| if you run multiple applications with the same cache engine. |
||||
|
| |
||||
|
*/ |
||||
|
public $prefix = ''; |
||||
|
|
||||
|
/* |
||||
|
| ------------------------------------------------------------------------- |
||||
|
| Memcached settings |
||||
|
| ------------------------------------------------------------------------- |
||||
|
| Your Memcached servers can be specified below, if you are using |
||||
|
| the Memcached drivers. |
||||
|
| |
||||
|
| See: https://codeigniter.com/user_guide/libraries/caching.html#memcached |
||||
|
| |
||||
|
*/ |
||||
|
public $memcached = [ |
||||
|
'host' => '127.0.0.1', |
||||
|
'port' => 11211, |
||||
|
'weight' => 1, |
||||
|
'raw' => false, |
||||
|
]; |
||||
|
|
||||
|
/* |
||||
|
| ------------------------------------------------------------------------- |
||||
|
| Redis settings |
||||
|
| ------------------------------------------------------------------------- |
||||
|
| Your Redis server can be specified below, if you are using |
||||
|
| the Redis or Predis drivers. |
||||
|
| |
||||
|
*/ |
||||
|
public $redis = [ |
||||
|
'host' => '127.0.0.1', |
||||
|
'password' => null, |
||||
|
'port' => 6379, |
||||
|
'timeout' => 0, |
||||
|
'database' => 0, |
||||
|
]; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Available Cache Handlers |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This is an array of cache engine alias' and class names. Only engines |
||||
|
| that are listed here are allowed to be used. |
||||
|
| |
||||
|
*/ |
||||
|
public $validHandlers = [ |
||||
|
'dummy' => \CodeIgniter\Cache\Handlers\DummyHandler::class, |
||||
|
'file' => \CodeIgniter\Cache\Handlers\FileHandler::class, |
||||
|
'memcached' => \CodeIgniter\Cache\Handlers\MemcachedHandler::class, |
||||
|
'predis' => \CodeIgniter\Cache\Handlers\PredisHandler::class, |
||||
|
'redis' => \CodeIgniter\Cache\Handlers\RedisHandler::class, |
||||
|
'wincache' => \CodeIgniter\Cache\Handlers\WincacheHandler::class, |
||||
|
]; |
||||
|
} |
@ -0,0 +1,77 @@ |
|||||
|
<?php |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
// App Namespace |
||||
|
//-------------------------------------------------------------------- |
||||
|
// This defines the default Namespace that is used throughout |
||||
|
// CodeIgniter to refer to the Application directory. Change |
||||
|
// this constant to change the namespace that all application |
||||
|
// classes should use. |
||||
|
// |
||||
|
// NOTE: changing this will require manually modifying the |
||||
|
// existing namespaces of App\* namespaced-classes. |
||||
|
// |
||||
|
defined('APP_NAMESPACE') || define('APP_NAMESPACE', 'App'); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Composer Path |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The path that Composer's autoload file is expected to live. By default, |
||||
|
| the vendor folder is in the Root directory, but you can customize that here. |
||||
|
*/ |
||||
|
defined('COMPOSER_PATH') || define('COMPOSER_PATH', ROOTPATH . 'vendor/autoload.php'); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Timing Constants |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Provide simple ways to work with the myriad of PHP functions that |
||||
|
| require information to be in seconds. |
||||
|
*/ |
||||
|
defined('SECOND') || define('SECOND', 1); |
||||
|
defined('MINUTE') || define('MINUTE', 60); |
||||
|
defined('HOUR') || define('HOUR', 3600); |
||||
|
defined('DAY') || define('DAY', 86400); |
||||
|
defined('WEEK') || define('WEEK', 604800); |
||||
|
defined('MONTH') || define('MONTH', 2592000); |
||||
|
defined('YEAR') || define('YEAR', 31536000); |
||||
|
defined('DECADE') || define('DECADE', 315360000); |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Exit Status Codes |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Used to indicate the conditions under which the script is exit()ing. |
||||
|
| While there is no universal standard for error codes, there are some |
||||
|
| broad conventions. Three such conventions are mentioned below, for |
||||
|
| those who wish to make use of them. The CodeIgniter defaults were |
||||
|
| chosen for the least overlap with these conventions, while still |
||||
|
| leaving room for others to be defined in future versions and user |
||||
|
| applications. |
||||
|
| |
||||
|
| The three main conventions used for determining exit status codes |
||||
|
| are as follows: |
||||
|
| |
||||
|
| Standard C/C++ Library (stdlibc): |
||||
|
| http://www.gnu.org/software/libc/manual/html_node/Exit-Status.html |
||||
|
| (This link also contains other GNU-specific conventions) |
||||
|
| BSD sysexits.h: |
||||
|
| http://www.gsp.com/cgi-bin/man.cgi?section=3&topic=sysexits |
||||
|
| Bash scripting: |
||||
|
| http://tldp.org/LDP/abs/html/exitcodes.html |
||||
|
| |
||||
|
*/ |
||||
|
defined('EXIT_SUCCESS') || define('EXIT_SUCCESS', 0); // no errors |
||||
|
defined('EXIT_ERROR') || define('EXIT_ERROR', 1); // generic error |
||||
|
defined('EXIT_CONFIG') || define('EXIT_CONFIG', 3); // configuration error |
||||
|
defined('EXIT_UNKNOWN_FILE') || define('EXIT_UNKNOWN_FILE', 4); // file not found |
||||
|
defined('EXIT_UNKNOWN_CLASS') || define('EXIT_UNKNOWN_CLASS', 5); // unknown class |
||||
|
defined('EXIT_UNKNOWN_METHOD') || define('EXIT_UNKNOWN_METHOD', 6); // unknown class member |
||||
|
defined('EXIT_USER_INPUT') || define('EXIT_USER_INPUT', 7); // invalid user input |
||||
|
defined('EXIT_DATABASE') || define('EXIT_DATABASE', 8); // database error |
||||
|
defined('EXIT__AUTO_MIN') || define('EXIT__AUTO_MIN', 9); // lowest automatically-assigned error code |
||||
|
defined('EXIT__AUTO_MAX') || define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code |
@ -0,0 +1,48 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
/** |
||||
|
* Class ContentSecurityPolicyConfig |
||||
|
* |
||||
|
* Stores the default settings for the ContentSecurityPolicy, if you |
||||
|
* choose to use it. The values here will be read in and set as defaults |
||||
|
* for the site. If needed, they can be overridden on a page-by-page basis. |
||||
|
* |
||||
|
* Suggested reference for explanations: |
||||
|
* https://www.html5rocks.com/en/tutorials/security/content-security-policy/ |
||||
|
* |
||||
|
* @package Config |
||||
|
*/ |
||||
|
class ContentSecurityPolicy extends BaseConfig |
||||
|
{ |
||||
|
// broadbrush CSP management |
||||
|
|
||||
|
public $reportOnly = false; // default CSP report context |
||||
|
public $reportURI = null; // URL to send violation reports to |
||||
|
public $upgradeInsecureRequests = false; // toggle for forcing https |
||||
|
|
||||
|
// sources allowed; string or array of strings |
||||
|
// Note: once you set a policy to 'none', it cannot be further restricted |
||||
|
|
||||
|
public $defaultSrc = null; // will default to self if not over-ridden |
||||
|
public $scriptSrc = 'self'; |
||||
|
public $styleSrc = 'self'; |
||||
|
public $imageSrc = 'self'; |
||||
|
public $baseURI = null; // will default to self if not over-ridden |
||||
|
public $childSrc = 'self'; |
||||
|
public $connectSrc = 'self'; |
||||
|
public $fontSrc = null; |
||||
|
public $formAction = 'self'; |
||||
|
public $frameAncestors = null; |
||||
|
public $mediaSrc = null; |
||||
|
public $objectSrc = 'self'; |
||||
|
public $manifestSrc = null; |
||||
|
|
||||
|
// mime types allowed; string or array of strings |
||||
|
public $pluginTypes = null; |
||||
|
|
||||
|
// list of actions allowed; string or array of strings |
||||
|
public $sandbox = null; |
||||
|
|
||||
|
} |
@ -0,0 +1,114 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
/** |
||||
|
* Database Configuration |
||||
|
* |
||||
|
* @package Config |
||||
|
*/ |
||||
|
|
||||
|
class Database extends \CodeIgniter\Database\Config |
||||
|
{ |
||||
|
/** |
||||
|
* The directory that holds the Migrations |
||||
|
* and Seeds directories. |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $filesPath = APPPATH . 'Database/'; |
||||
|
|
||||
|
/** |
||||
|
* Lets you choose which connection group to |
||||
|
* use if no other is specified. |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $defaultGroup = 'default'; |
||||
|
|
||||
|
/** |
||||
|
* The default database connection. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public $default = [ |
||||
|
'DSN' => '', |
||||
|
'hostname' => 'localhost', |
||||
|
'username' => '', |
||||
|
'password' => '', |
||||
|
'database' => '/var/www/rhays.us/Examples/games/rpsls/app/Database/game.db', |
||||
|
'DBDriver' => 'SQLite3', |
||||
|
'DBPrefix' => '', |
||||
|
'pConnect' => false, |
||||
|
'DBDebug' => (ENVIRONMENT !== 'production'), |
||||
|
'cacheOn' => false, |
||||
|
'cacheDir' => '', |
||||
|
'charset' => 'utf8', |
||||
|
'DBCollat' => 'utf8_general_ci', |
||||
|
'swapPre' => '', |
||||
|
'encrypt' => false, |
||||
|
'compress' => false, |
||||
|
'strictOn' => false, |
||||
|
'failover' => [], |
||||
|
'port' => 3306, |
||||
|
]; |
||||
|
|
||||
|
/** |
||||
|
* This database connection is used when |
||||
|
* running PHPUnit database tests. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public $tests = [ |
||||
|
'DSN' => '', |
||||
|
'hostname' => '127.0.0.1', |
||||
|
'username' => '', |
||||
|
'password' => '', |
||||
|
'database' => '', |
||||
|
'DBDriver' => '', |
||||
|
'DBPrefix' => 'db_', // Needed to ensure we're working correctly with prefixes live. DO NOT REMOVE. |
||||
|
'pConnect' => false, |
||||
|
'DBDebug' => (ENVIRONMENT !== 'production'), |
||||
|
'cacheOn' => false, |
||||
|
'cacheDir' => '', |
||||
|
'charset' => 'utf8', |
||||
|
'DBCollat' => 'utf8_general_ci', |
||||
|
'swapPre' => '', |
||||
|
'encrypt' => false, |
||||
|
'compress' => false, |
||||
|
'strictOn' => false, |
||||
|
'failover' => [], |
||||
|
'port' => 3306, |
||||
|
]; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
public function __construct() |
||||
|
{ |
||||
|
parent::__construct(); |
||||
|
|
||||
|
// Ensure that we always set the database group to 'tests' if |
||||
|
// we are currently running an automated test suite, so that |
||||
|
// we don't overwrite live data on accident. |
||||
|
if (ENVIRONMENT === 'testing') |
||||
|
{ |
||||
|
$this->defaultGroup = 'tests'; |
||||
|
|
||||
|
// Under Travis-CI, we can set an ENV var named 'DB_GROUP' |
||||
|
// so that we can test against multiple databases. |
||||
|
if ($group = getenv('DB')) |
||||
|
{ |
||||
|
if (is_file(TESTPATH . 'travis/Database.php')) |
||||
|
{ |
||||
|
require TESTPATH . 'travis/Database.php'; |
||||
|
|
||||
|
if (! empty($dbconfig) && array_key_exists($group, $dbconfig)) |
||||
|
{ |
||||
|
$this->tests = $dbconfig[$group]; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
} |
@ -0,0 +1,33 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
/** |
||||
|
* DocTypes |
||||
|
* |
||||
|
* @package Config |
||||
|
*/ |
||||
|
|
||||
|
class DocTypes |
||||
|
{ |
||||
|
public $list = |
||||
|
[ |
||||
|
'xhtml11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">', |
||||
|
'xhtml1-strict' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">', |
||||
|
'xhtml1-trans' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">', |
||||
|
'xhtml1-frame' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">', |
||||
|
'xhtml-basic11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.1//EN" "http://www.w3.org/TR/xhtml-basic/xhtml-basic11.dtd">', |
||||
|
'html5' => '<!DOCTYPE html>', |
||||
|
'html4-strict' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">', |
||||
|
'html4-trans' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">', |
||||
|
'html4-frame' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">', |
||||
|
'mathml1' => '<!DOCTYPE math SYSTEM "http://www.w3.org/Math/DTD/mathml1/mathml.dtd">', |
||||
|
'mathml2' => '<!DOCTYPE math PUBLIC "-//W3C//DTD MathML 2.0//EN" "http://www.w3.org/Math/DTD/mathml2/mathml2.dtd">', |
||||
|
'svg10' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">', |
||||
|
'svg11' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">', |
||||
|
'svg11-basic' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Basic//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-basic.dtd">', |
||||
|
'svg11-tiny' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Tiny//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-tiny.dtd">', |
||||
|
'xhtml-math-svg-xh' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0 plus SVG 1.1//EN" "http://www.w3.org/2002/04/xhtml-math-svg/xhtml-math-svg.dtd">', |
||||
|
'xhtml-math-svg-sh' => '<!DOCTYPE svg:svg PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0 plus SVG 1.1//EN" "http://www.w3.org/2002/04/xhtml-math-svg/xhtml-math-svg.dtd">', |
||||
|
'xhtml-rdfa-1' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.0//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-1.dtd">', |
||||
|
'xhtml-rdfa-2' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.1//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-2.dtd">', |
||||
|
]; |
||||
|
} |
@ -0,0 +1,164 @@ |
|||||
|
<?php |
||||
|
namespace Config; |
||||
|
|
||||
|
class Email |
||||
|
{ |
||||
|
|
||||
|
/** |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $fromEmail; |
||||
|
|
||||
|
/** |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $fromName; |
||||
|
|
||||
|
/** |
||||
|
* The "user agent" |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $userAgent = 'CodeIgniter'; |
||||
|
|
||||
|
/** |
||||
|
* The mail sending protocol: mail, sendmail, smtp |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $protocol = 'mail'; |
||||
|
|
||||
|
/** |
||||
|
* The server path to Sendmail. |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $mailPath = '/usr/sbin/sendmail'; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Server Address |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $SMTPHost; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Username |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $SMTPUser; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Password |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $SMTPPass; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Port |
||||
|
* |
||||
|
* @var integer |
||||
|
*/ |
||||
|
public $SMTPPort = 25; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Timeout (in seconds) |
||||
|
* |
||||
|
* @var integer |
||||
|
*/ |
||||
|
public $SMTPTimeout = 5; |
||||
|
|
||||
|
/** |
||||
|
* Enable persistent SMTP connections |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $SMTPKeepAlive = false; |
||||
|
|
||||
|
/** |
||||
|
* SMTP Encryption. Either tls or ssl |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $SMTPCrypto = 'tls'; |
||||
|
|
||||
|
/** |
||||
|
* Enable word-wrap |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $wordWrap = true; |
||||
|
|
||||
|
/** |
||||
|
* Character count to wrap at |
||||
|
* |
||||
|
* @var integer |
||||
|
*/ |
||||
|
public $wrapChars = 76; |
||||
|
|
||||
|
/** |
||||
|
* Type of mail, either 'text' or 'html' |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $mailType = 'text'; |
||||
|
|
||||
|
/** |
||||
|
* Character set (utf-8, iso-8859-1, etc.) |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $charset = 'UTF-8'; |
||||
|
|
||||
|
/** |
||||
|
* Whether to validate the email address |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $validate = false; |
||||
|
|
||||
|
/** |
||||
|
* Email Priority. 1 = highest. 5 = lowest. 3 = normal |
||||
|
* |
||||
|
* @var integer |
||||
|
*/ |
||||
|
public $priority = 3; |
||||
|
|
||||
|
/** |
||||
|
* Newline character. (Use “\r\n” to comply with RFC 822) |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $CRLF = "\r\n"; |
||||
|
|
||||
|
/** |
||||
|
* Newline character. (Use “\r\n” to comply with RFC 822) |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $newline = "\r\n"; |
||||
|
|
||||
|
/** |
||||
|
* Enable BCC Batch Mode. |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $BCCBatchMode = false; |
||||
|
|
||||
|
/** |
||||
|
* Number of emails in each BCC batch |
||||
|
* |
||||
|
* @var integer |
||||
|
*/ |
||||
|
public $BCCBatchSize = 200; |
||||
|
|
||||
|
/** |
||||
|
* Enable notify message from server |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $DSN = false; |
||||
|
|
||||
|
} |
@ -0,0 +1,36 @@ |
|||||
|
<?php |
||||
|
namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
/** |
||||
|
* Encryption configuration. |
||||
|
* |
||||
|
* These are the settings used for encryption, if you don't pass a parameter |
||||
|
* array to the encrypter for creation/initialization. |
||||
|
*/ |
||||
|
class Encryption extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Encryption Key Starter |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If you use the Encryption class you must set an encryption key (seed). |
||||
|
| You need to ensure it is long enough for the cipher and mode you plan to use. |
||||
|
| See the user guide for more info. |
||||
|
*/ |
||||
|
|
||||
|
public $key = ''; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Encryption driver to use |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| One of the supported drivers, eg 'OpenSSL' or 'Sodium'. |
||||
|
| The default driver, if you don't specify one, is 'OpenSSL'. |
||||
|
*/ |
||||
|
public $driver = 'OpenSSL'; |
||||
|
|
||||
|
} |
@ -0,0 +1,43 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Events\Events; |
||||
|
|
||||
|
/* |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Application Events |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Events allow you to tap into the execution of the program without |
||||
|
* modifying or extending core files. This file provides a central |
||||
|
* location to define your events, though they can always be added |
||||
|
* at run-time, also, if needed. |
||||
|
* |
||||
|
* You create code that can execute by subscribing to events with |
||||
|
* the 'on()' method. This accepts any form of callable, including |
||||
|
* Closures, that will be executed when the event is triggered. |
||||
|
* |
||||
|
* Example: |
||||
|
* Events::on('create', [$myInstance, 'myMethod']); |
||||
|
*/ |
||||
|
|
||||
|
Events::on('pre_system', function () { |
||||
|
while (\ob_get_level() > 0) |
||||
|
{ |
||||
|
\ob_end_flush(); |
||||
|
} |
||||
|
|
||||
|
\ob_start(function ($buffer) { |
||||
|
return $buffer; |
||||
|
}); |
||||
|
|
||||
|
/* |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Debug Toolbar Listeners. |
||||
|
* -------------------------------------------------------------------- |
||||
|
* If you delete, they will no longer be collected. |
||||
|
*/ |
||||
|
if (ENVIRONMENT !== 'production') |
||||
|
{ |
||||
|
Events::on('DBQuery', 'CodeIgniter\Debug\Toolbar\Collectors\Database::collect'); |
||||
|
Services::toolbar()->respond(); |
||||
|
} |
||||
|
}); |
@ -0,0 +1,41 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
/** |
||||
|
* Setup how the exception handler works. |
||||
|
* |
||||
|
* @package Config |
||||
|
*/ |
||||
|
|
||||
|
class Exceptions |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| LOG EXCEPTIONS? |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| If true, then exceptions will be logged |
||||
|
| through Services::Log. |
||||
|
| |
||||
|
| Default: true |
||||
|
*/ |
||||
|
public $log = true; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| DO NOT LOG STATUS CODES |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Any status codes here will NOT be logged if logging is turned on. |
||||
|
| By default, only 404 (Page Not Found) exceptions are ignored. |
||||
|
*/ |
||||
|
public $ignoreCodes = [ 404 ]; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Error Views Path |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| This is the path to the directory that contains the 'cli' and 'html' |
||||
|
| directories that hold the views used to generate errors. |
||||
|
| |
||||
|
| Default: APPPATH.'Views/errors' |
||||
|
*/ |
||||
|
public $errorViewPath = APPPATH . 'Views/errors'; |
||||
|
} |
@ -0,0 +1,39 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Filters extends BaseConfig |
||||
|
{ |
||||
|
// Makes reading things below nicer, |
||||
|
// and simpler to change out script that's used. |
||||
|
public $aliases = [ |
||||
|
'csrf' => \CodeIgniter\Filters\CSRF::class, |
||||
|
'toolbar' => \CodeIgniter\Filters\DebugToolbar::class, |
||||
|
'honeypot' => \CodeIgniter\Filters\Honeypot::class, |
||||
|
'game' => \App\Filters\GameFilters::class, |
||||
|
]; |
||||
|
|
||||
|
// Always applied before every request |
||||
|
public $globals = [ |
||||
|
'before' => [ |
||||
|
//'honeypot', |
||||
|
//'csrf', |
||||
|
'game' => ['except' => 'setup'], |
||||
|
], |
||||
|
'after' => [ |
||||
|
'toolbar', |
||||
|
//'honeypot' |
||||
|
], |
||||
|
]; |
||||
|
|
||||
|
// Works on all of a particular HTTP method |
||||
|
// (GET, POST, etc) as BEFORE filters only |
||||
|
// like: 'post' => ['CSRF', 'throttle'], |
||||
|
public $methods = []; |
||||
|
|
||||
|
// List filter aliases and any before/after uri patterns |
||||
|
// that they should run on, like: |
||||
|
// 'isLoggedIn' => ['before' => ['account/*', 'profiles/*']], |
||||
|
public $filters = []; |
||||
|
|
||||
|
} |
@ -0,0 +1,6 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
class ForeignCharacters extends \CodeIgniter\Config\ForeignCharacters |
||||
|
{ |
||||
|
|
||||
|
} |
@ -0,0 +1,71 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Format extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Available Response Formats |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| When you perform content negotiation with the request, these are the |
||||
|
| available formats that your application supports. This is currently |
||||
|
| only used with the API\ResponseTrait. A valid Formatter must exist |
||||
|
| for the specified format. |
||||
|
| |
||||
|
| These formats are only checked when the data passed to the respond() |
||||
|
| method is an array. |
||||
|
| |
||||
|
*/ |
||||
|
public $supportedResponseFormats = [ |
||||
|
'application/json', |
||||
|
'application/xml', // machine-readable XML |
||||
|
'text/xml', // human-readable XML |
||||
|
]; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Formatters |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Lists the class to use to format responses with of a particular type. |
||||
|
| For each mime type, list the class that should be used. Formatters |
||||
|
| can be retrieved through the getFormatter() method. |
||||
|
| |
||||
|
*/ |
||||
|
public $formatters = [ |
||||
|
'application/json' => \CodeIgniter\Format\JSONFormatter::class, |
||||
|
'application/xml' => \CodeIgniter\Format\XMLFormatter::class, |
||||
|
'text/xml' => \CodeIgniter\Format\XMLFormatter::class, |
||||
|
]; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
/** |
||||
|
* A Factory method to return the appropriate formatter for the given mime type. |
||||
|
* |
||||
|
* @param string $mime |
||||
|
* |
||||
|
* @return \CodeIgniter\Format\FormatterInterface |
||||
|
*/ |
||||
|
public function getFormatter(string $mime) |
||||
|
{ |
||||
|
if (! array_key_exists($mime, $this->formatters)) |
||||
|
{ |
||||
|
throw new \InvalidArgumentException('No Formatter defined for mime type: ' . $mime); |
||||
|
} |
||||
|
|
||||
|
$class = $this->formatters[$mime]; |
||||
|
|
||||
|
if (! class_exists($class)) |
||||
|
{ |
||||
|
throw new \BadMethodCallException($class . ' is not a valid Formatter.'); |
||||
|
} |
||||
|
|
||||
|
return new $class(); |
||||
|
} |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
} |
@ -0,0 +1,34 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Honeypot extends BaseConfig |
||||
|
{ |
||||
|
|
||||
|
/** |
||||
|
* Makes Honeypot visible or not to human |
||||
|
* |
||||
|
* @var boolean |
||||
|
*/ |
||||
|
public $hidden = true; |
||||
|
/** |
||||
|
* Honeypot Label Content |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $label = 'Fill This Field'; |
||||
|
|
||||
|
/** |
||||
|
* Honeypot Field Name |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $name = 'honeypot'; |
||||
|
|
||||
|
/** |
||||
|
* Honeypot HTML Template |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $template = '<label>{label}</label><input type="text" name="{name}" value=""/>'; |
||||
|
} |
@ -0,0 +1,31 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Images extends BaseConfig |
||||
|
{ |
||||
|
/** |
||||
|
* Default handler used if no other handler is specified. |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $defaultHandler = 'gd'; |
||||
|
|
||||
|
/** |
||||
|
* The path to the image library. |
||||
|
* Required for ImageMagick, GraphicsMagick, or NetPBM. |
||||
|
* |
||||
|
* @var string |
||||
|
*/ |
||||
|
public $libraryPath = '/usr/local/bin/convert'; |
||||
|
|
||||
|
/** |
||||
|
* The available handler classes. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public $handlers = [ |
||||
|
'gd' => \CodeIgniter\Images\Handlers\GDHandler::class, |
||||
|
'imagick' => \CodeIgniter\Images\Handlers\ImageMagickHandler::class, |
||||
|
]; |
||||
|
} |
@ -0,0 +1,140 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Logger extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Error Logging Threshold |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| You can enable error logging by setting a threshold over zero. The |
||||
|
| threshold determines what gets logged. Any values below or equal to the |
||||
|
| threshold will be logged. Threshold options are: |
||||
|
| |
||||
|
| 0 = Disables logging, Error logging TURNED OFF |
||||
|
| 1 = Emergency Messages - System is unusable |
||||
|
| 2 = Alert Messages - Action Must Be Taken Immediately |
||||
|
| 3 = Critical Messages - Application component unavailable, unexpected exception. |
||||
|
| 4 = Runtime Errors - Don't need immediate action, but should be monitored. |
||||
|
| 5 = Warnings - Exceptional occurrences that are not errors. |
||||
|
| 6 = Notices - Normal but significant events. |
||||
|
| 7 = Info - Interesting events, like user logging in, etc. |
||||
|
| 8 = Debug - Detailed debug information. |
||||
|
| 9 = All Messages |
||||
|
| |
||||
|
| You can also pass an array with threshold levels to show individual error types |
||||
|
| |
||||
|
| array(1, 2, 3, 8) = Emergency, Alert, Critical, and Debug messages |
||||
|
| |
||||
|
| For a live site you'll usually enable Critical or higher (3) to be logged otherwise |
||||
|
| your log files will fill up very fast. |
||||
|
| |
||||
|
*/ |
||||
|
public $threshold = 3; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Error Logging Directory Path |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| |
||||
|
| |
||||
|
*/ |
||||
|
public $path = ''; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Date Format for Logs |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Each item that is logged has an associated date. You can use PHP date |
||||
|
| codes to set your own date formatting |
||||
|
| |
||||
|
*/ |
||||
|
public $dateFormat = 'Y-m-d H:i:s'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Log Handlers |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The logging system supports multiple actions to be taken when something |
||||
|
| is logged. This is done by allowing for multiple Handlers, special classes |
||||
|
| designed to write the log to their chosen destinations, whether that is |
||||
|
| a file on the getServer, a cloud-based service, or even taking actions such |
||||
|
| as emailing the dev team. |
||||
|
| |
||||
|
| Each handler is defined by the class name used for that handler, and it |
||||
|
| MUST implement the CodeIgniter\Log\Handlers\HandlerInterface interface. |
||||
|
| |
||||
|
| The value of each key is an array of configuration items that are sent |
||||
|
| to the constructor of each handler. The only required configuration item |
||||
|
| is the 'handles' element, which must be an array of integer log levels. |
||||
|
| This is most easily handled by using the constants defined in the |
||||
|
| Psr\Log\LogLevel class. |
||||
|
| |
||||
|
| Handlers are executed in the order defined in this array, starting with |
||||
|
| the handler on top and continuing down. |
||||
|
| |
||||
|
*/ |
||||
|
public $handlers = [ |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
// File Handler |
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
'CodeIgniter\Log\Handlers\FileHandler' => [ |
||||
|
|
||||
|
/* |
||||
|
* The log levels that this handler will handle. |
||||
|
*/ |
||||
|
'handles' => [ |
||||
|
'critical', |
||||
|
'alert', |
||||
|
'emergency', |
||||
|
'debug', |
||||
|
'error', |
||||
|
'info', |
||||
|
'notice', |
||||
|
'warning', |
||||
|
], |
||||
|
|
||||
|
/* |
||||
|
* Leave this BLANK unless you would like to set something other than the default |
||||
|
* writeable/logs/ directory. Use a full getServer path with trailing slash. |
||||
|
*/ |
||||
|
'path' => WRITEPATH . 'logs/', |
||||
|
|
||||
|
/* |
||||
|
* The default filename extension for log files. The default 'php' allows for |
||||
|
* protecting the log files via basic scripting, when they are to be stored |
||||
|
* under a publicly accessible directory. |
||||
|
* |
||||
|
* Note: Leaving it blank will default to 'php'. |
||||
|
*/ |
||||
|
'fileExtension' => 'php', |
||||
|
|
||||
|
/* |
||||
|
* The file system permissions to be applied on newly created log files. |
||||
|
* |
||||
|
* IMPORTANT: This MUST be an integer (no quotes) and you MUST use octal |
||||
|
* integer notation (i.e. 0700, 0644, etc.) |
||||
|
*/ |
||||
|
'filePermissions' => 0644, |
||||
|
], |
||||
|
|
||||
|
/** |
||||
|
* The ChromeLoggerHandler requires the use of the Chrome web browser |
||||
|
* and the ChromeLogger extension. Uncomment this block to use it. |
||||
|
*/ |
||||
|
// 'CodeIgniter\Log\Handlers\ChromeLoggerHandler' => [ |
||||
|
// /* |
||||
|
// * The log levels that this handler will handle. |
||||
|
// */ |
||||
|
// 'handles' => ['critical', 'alert', 'emergency', 'debug', |
||||
|
// 'error', 'info', 'notice', 'warning'], |
||||
|
// ] |
||||
|
]; |
||||
|
} |
@ -0,0 +1,50 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Migrations extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Enable/Disable Migrations |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Migrations are enabled by default for security reasons. |
||||
|
| You should enable migrations whenever you intend to do a schema migration |
||||
|
| and disable it back when you're done. |
||||
|
| |
||||
|
*/ |
||||
|
public $enabled = true; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Migrations table |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This is the name of the table that will store the current migrations state. |
||||
|
| When migrations runs it will store in a database table which migration |
||||
|
| level the system is at. It then compares the migration level in this |
||||
|
| table to the $config['migration_version'] if they are not the same it |
||||
|
| will migrate up. This must be set. |
||||
|
| |
||||
|
*/ |
||||
|
public $table = 'migrations'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Timestamp Format |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| This is the format that will be used when creating new migrations |
||||
|
| using the cli command: |
||||
|
| > php spark migrate:create |
||||
|
| |
||||
|
| Typical formats: |
||||
|
| YmdHis_ |
||||
|
| Y-m-d-His_ |
||||
|
| Y_m_d_His_ |
||||
|
| |
||||
|
*/ |
||||
|
public $timestampFormat = 'Y-m-d-His_'; |
||||
|
|
||||
|
} |
@ -0,0 +1,534 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
/* |
||||
|
| ------------------------------------------------------------------- |
||||
|
| MIME TYPES |
||||
|
| ------------------------------------------------------------------- |
||||
|
| This file contains an array of mime types. It is used by the |
||||
|
| Upload class to help identify allowed file types. |
||||
|
| |
||||
|
| When more than one variation for an extension exist (like jpg, jpeg, etc) |
||||
|
| the most common one should be first in the array to aid the guess* |
||||
|
| methods. The same applies when more than one mime-type exists for a |
||||
|
| single extension. |
||||
|
| |
||||
|
*/ |
||||
|
class Mimes |
||||
|
{ |
||||
|
/** |
||||
|
* Map of extensions to mime types. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public static $mimes = [ |
||||
|
'hqx' => [ |
||||
|
'application/mac-binhex40', |
||||
|
'application/mac-binhex', |
||||
|
'application/x-binhex40', |
||||
|
'application/x-mac-binhex40', |
||||
|
], |
||||
|
'cpt' => 'application/mac-compactpro', |
||||
|
'csv' => [ |
||||
|
'text/csv', |
||||
|
'text/x-comma-separated-values', |
||||
|
'text/comma-separated-values', |
||||
|
'application/octet-stream', |
||||
|
'application/vnd.ms-excel', |
||||
|
'application/x-csv', |
||||
|
'text/x-csv', |
||||
|
'application/csv', |
||||
|
'application/excel', |
||||
|
'application/vnd.msexcel', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'bin' => [ |
||||
|
'application/macbinary', |
||||
|
'application/mac-binary', |
||||
|
'application/octet-stream', |
||||
|
'application/x-binary', |
||||
|
'application/x-macbinary', |
||||
|
], |
||||
|
'dms' => 'application/octet-stream', |
||||
|
'lha' => 'application/octet-stream', |
||||
|
'lzh' => 'application/octet-stream', |
||||
|
'exe' => [ |
||||
|
'application/octet-stream', |
||||
|
'application/x-msdownload', |
||||
|
], |
||||
|
'class' => 'application/octet-stream', |
||||
|
'psd' => [ |
||||
|
'application/x-photoshop', |
||||
|
'image/vnd.adobe.photoshop', |
||||
|
], |
||||
|
'so' => 'application/octet-stream', |
||||
|
'sea' => 'application/octet-stream', |
||||
|
'dll' => 'application/octet-stream', |
||||
|
'oda' => 'application/oda', |
||||
|
'pdf' => [ |
||||
|
'application/pdf', |
||||
|
'application/force-download', |
||||
|
'application/x-download', |
||||
|
'binary/octet-stream', |
||||
|
], |
||||
|
'ai' => [ |
||||
|
'application/pdf', |
||||
|
'application/postscript', |
||||
|
], |
||||
|
'eps' => 'application/postscript', |
||||
|
'ps' => 'application/postscript', |
||||
|
'smi' => 'application/smil', |
||||
|
'smil' => 'application/smil', |
||||
|
'mif' => 'application/vnd.mif', |
||||
|
'xls' => [ |
||||
|
'application/vnd.ms-excel', |
||||
|
'application/msexcel', |
||||
|
'application/x-msexcel', |
||||
|
'application/x-ms-excel', |
||||
|
'application/x-excel', |
||||
|
'application/x-dos_ms_excel', |
||||
|
'application/xls', |
||||
|
'application/x-xls', |
||||
|
'application/excel', |
||||
|
'application/download', |
||||
|
'application/vnd.ms-office', |
||||
|
'application/msword', |
||||
|
], |
||||
|
'ppt' => [ |
||||
|
'application/vnd.ms-powerpoint', |
||||
|
'application/powerpoint', |
||||
|
'application/vnd.ms-office', |
||||
|
'application/msword', |
||||
|
], |
||||
|
'pptx' => [ |
||||
|
'application/vnd.openxmlformats-officedocument.presentationml.presentation', |
||||
|
'application/x-zip', |
||||
|
'application/zip', |
||||
|
], |
||||
|
'wbxml' => 'application/wbxml', |
||||
|
'wmlc' => 'application/wmlc', |
||||
|
'dcr' => 'application/x-director', |
||||
|
'dir' => 'application/x-director', |
||||
|
'dxr' => 'application/x-director', |
||||
|
'dvi' => 'application/x-dvi', |
||||
|
'gtar' => 'application/x-gtar', |
||||
|
'gz' => 'application/x-gzip', |
||||
|
'gzip' => 'application/x-gzip', |
||||
|
'php' => [ |
||||
|
'application/x-php', |
||||
|
'application/x-httpd-php', |
||||
|
'application/php', |
||||
|
'text/php', |
||||
|
'text/x-php', |
||||
|
'application/x-httpd-php-source', |
||||
|
], |
||||
|
'php4' => 'application/x-httpd-php', |
||||
|
'php3' => 'application/x-httpd-php', |
||||
|
'phtml' => 'application/x-httpd-php', |
||||
|
'phps' => 'application/x-httpd-php-source', |
||||
|
'js' => [ |
||||
|
'application/x-javascript', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'swf' => 'application/x-shockwave-flash', |
||||
|
'sit' => 'application/x-stuffit', |
||||
|
'tar' => 'application/x-tar', |
||||
|
'tgz' => [ |
||||
|
'application/x-tar', |
||||
|
'application/x-gzip-compressed', |
||||
|
], |
||||
|
'z' => 'application/x-compress', |
||||
|
'xhtml' => 'application/xhtml+xml', |
||||
|
'xht' => 'application/xhtml+xml', |
||||
|
'zip' => [ |
||||
|
'application/x-zip', |
||||
|
'application/zip', |
||||
|
'application/x-zip-compressed', |
||||
|
'application/s-compressed', |
||||
|
'multipart/x-zip', |
||||
|
], |
||||
|
'rar' => [ |
||||
|
'application/x-rar', |
||||
|
'application/rar', |
||||
|
'application/x-rar-compressed', |
||||
|
], |
||||
|
'mid' => 'audio/midi', |
||||
|
'midi' => 'audio/midi', |
||||
|
'mpga' => 'audio/mpeg', |
||||
|
'mp2' => 'audio/mpeg', |
||||
|
'mp3' => [ |
||||
|
'audio/mpeg', |
||||
|
'audio/mpg', |
||||
|
'audio/mpeg3', |
||||
|
'audio/mp3', |
||||
|
], |
||||
|
'aif' => [ |
||||
|
'audio/x-aiff', |
||||
|
'audio/aiff', |
||||
|
], |
||||
|
'aiff' => [ |
||||
|
'audio/x-aiff', |
||||
|
'audio/aiff', |
||||
|
], |
||||
|
'aifc' => 'audio/x-aiff', |
||||
|
'ram' => 'audio/x-pn-realaudio', |
||||
|
'rm' => 'audio/x-pn-realaudio', |
||||
|
'rpm' => 'audio/x-pn-realaudio-plugin', |
||||
|
'ra' => 'audio/x-realaudio', |
||||
|
'rv' => 'video/vnd.rn-realvideo', |
||||
|
'wav' => [ |
||||
|
'audio/x-wav', |
||||
|
'audio/wave', |
||||
|
'audio/wav', |
||||
|
], |
||||
|
'bmp' => [ |
||||
|
'image/bmp', |
||||
|
'image/x-bmp', |
||||
|
'image/x-bitmap', |
||||
|
'image/x-xbitmap', |
||||
|
'image/x-win-bitmap', |
||||
|
'image/x-windows-bmp', |
||||
|
'image/ms-bmp', |
||||
|
'image/x-ms-bmp', |
||||
|
'application/bmp', |
||||
|
'application/x-bmp', |
||||
|
'application/x-win-bitmap', |
||||
|
], |
||||
|
'gif' => 'image/gif', |
||||
|
'jpg' => [ |
||||
|
'image/jpeg', |
||||
|
'image/pjpeg', |
||||
|
], |
||||
|
'jpeg' => [ |
||||
|
'image/jpeg', |
||||
|
'image/pjpeg', |
||||
|
], |
||||
|
'jpe' => [ |
||||
|
'image/jpeg', |
||||
|
'image/pjpeg', |
||||
|
], |
||||
|
'jp2' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'j2k' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'jpf' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'jpg2' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'jpx' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'jpm' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'mj2' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'mjp2' => [ |
||||
|
'image/jp2', |
||||
|
'video/mj2', |
||||
|
'image/jpx', |
||||
|
'image/jpm', |
||||
|
], |
||||
|
'png' => [ |
||||
|
'image/png', |
||||
|
'image/x-png', |
||||
|
], |
||||
|
'tif' => 'image/tiff', |
||||
|
'tiff' => 'image/tiff', |
||||
|
'css' => [ |
||||
|
'text/css', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'html' => [ |
||||
|
'text/html', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'htm' => [ |
||||
|
'text/html', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'shtml' => [ |
||||
|
'text/html', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'txt' => 'text/plain', |
||||
|
'text' => 'text/plain', |
||||
|
'log' => [ |
||||
|
'text/plain', |
||||
|
'text/x-log', |
||||
|
], |
||||
|
'rtx' => 'text/richtext', |
||||
|
'rtf' => 'text/rtf', |
||||
|
'xml' => [ |
||||
|
'application/xml', |
||||
|
'text/xml', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'xsl' => [ |
||||
|
'application/xml', |
||||
|
'text/xsl', |
||||
|
'text/xml', |
||||
|
], |
||||
|
'mpeg' => 'video/mpeg', |
||||
|
'mpg' => 'video/mpeg', |
||||
|
'mpe' => 'video/mpeg', |
||||
|
'qt' => 'video/quicktime', |
||||
|
'mov' => 'video/quicktime', |
||||
|
'avi' => [ |
||||
|
'video/x-msvideo', |
||||
|
'video/msvideo', |
||||
|
'video/avi', |
||||
|
'application/x-troff-msvideo', |
||||
|
], |
||||
|
'movie' => 'video/x-sgi-movie', |
||||
|
'doc' => [ |
||||
|
'application/msword', |
||||
|
'application/vnd.ms-office', |
||||
|
], |
||||
|
'docx' => [ |
||||
|
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', |
||||
|
'application/zip', |
||||
|
'application/msword', |
||||
|
'application/x-zip', |
||||
|
], |
||||
|
'dot' => [ |
||||
|
'application/msword', |
||||
|
'application/vnd.ms-office', |
||||
|
], |
||||
|
'dotx' => [ |
||||
|
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', |
||||
|
'application/zip', |
||||
|
'application/msword', |
||||
|
], |
||||
|
'xlsx' => [ |
||||
|
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', |
||||
|
'application/zip', |
||||
|
'application/vnd.ms-excel', |
||||
|
'application/msword', |
||||
|
'application/x-zip', |
||||
|
], |
||||
|
'word' => [ |
||||
|
'application/msword', |
||||
|
'application/octet-stream', |
||||
|
], |
||||
|
'xl' => 'application/excel', |
||||
|
'eml' => 'message/rfc822', |
||||
|
'json' => [ |
||||
|
'application/json', |
||||
|
'text/json', |
||||
|
], |
||||
|
'pem' => [ |
||||
|
'application/x-x509-user-cert', |
||||
|
'application/x-pem-file', |
||||
|
'application/octet-stream', |
||||
|
], |
||||
|
'p10' => [ |
||||
|
'application/x-pkcs10', |
||||
|
'application/pkcs10', |
||||
|
], |
||||
|
'p12' => 'application/x-pkcs12', |
||||
|
'p7a' => 'application/x-pkcs7-signature', |
||||
|
'p7c' => [ |
||||
|
'application/pkcs7-mime', |
||||
|
'application/x-pkcs7-mime', |
||||
|
], |
||||
|
'p7m' => [ |
||||
|
'application/pkcs7-mime', |
||||
|
'application/x-pkcs7-mime', |
||||
|
], |
||||
|
'p7r' => 'application/x-pkcs7-certreqresp', |
||||
|
'p7s' => 'application/pkcs7-signature', |
||||
|
'crt' => [ |
||||
|
'application/x-x509-ca-cert', |
||||
|
'application/x-x509-user-cert', |
||||
|
'application/pkix-cert', |
||||
|
], |
||||
|
'crl' => [ |
||||
|
'application/pkix-crl', |
||||
|
'application/pkcs-crl', |
||||
|
], |
||||
|
'der' => 'application/x-x509-ca-cert', |
||||
|
'kdb' => 'application/octet-stream', |
||||
|
'pgp' => 'application/pgp', |
||||
|
'gpg' => 'application/gpg-keys', |
||||
|
'sst' => 'application/octet-stream', |
||||
|
'csr' => 'application/octet-stream', |
||||
|
'rsa' => 'application/x-pkcs7', |
||||
|
'cer' => [ |
||||
|
'application/pkix-cert', |
||||
|
'application/x-x509-ca-cert', |
||||
|
], |
||||
|
'3g2' => 'video/3gpp2', |
||||
|
'3gp' => [ |
||||
|
'video/3gp', |
||||
|
'video/3gpp', |
||||
|
], |
||||
|
'mp4' => 'video/mp4', |
||||
|
'm4a' => 'audio/x-m4a', |
||||
|
'f4v' => [ |
||||
|
'video/mp4', |
||||
|
'video/x-f4v', |
||||
|
], |
||||
|
'flv' => 'video/x-flv', |
||||
|
'webm' => 'video/webm', |
||||
|
'aac' => 'audio/x-acc', |
||||
|
'm4u' => 'application/vnd.mpegurl', |
||||
|
'm3u' => 'text/plain', |
||||
|
'xspf' => 'application/xspf+xml', |
||||
|
'vlc' => 'application/videolan', |
||||
|
'wmv' => [ |
||||
|
'video/x-ms-wmv', |
||||
|
'video/x-ms-asf', |
||||
|
], |
||||
|
'au' => 'audio/x-au', |
||||
|
'ac3' => 'audio/ac3', |
||||
|
'flac' => 'audio/x-flac', |
||||
|
'ogg' => [ |
||||
|
'audio/ogg', |
||||
|
'video/ogg', |
||||
|
'application/ogg', |
||||
|
], |
||||
|
'kmz' => [ |
||||
|
'application/vnd.google-earth.kmz', |
||||
|
'application/zip', |
||||
|
'application/x-zip', |
||||
|
], |
||||
|
'kml' => [ |
||||
|
'application/vnd.google-earth.kml+xml', |
||||
|
'application/xml', |
||||
|
'text/xml', |
||||
|
], |
||||
|
'ics' => 'text/calendar', |
||||
|
'ical' => 'text/calendar', |
||||
|
'zsh' => 'text/x-scriptzsh', |
||||
|
'7zip' => [ |
||||
|
'application/x-compressed', |
||||
|
'application/x-zip-compressed', |
||||
|
'application/zip', |
||||
|
'multipart/x-zip', |
||||
|
], |
||||
|
'cdr' => [ |
||||
|
'application/cdr', |
||||
|
'application/coreldraw', |
||||
|
'application/x-cdr', |
||||
|
'application/x-coreldraw', |
||||
|
'image/cdr', |
||||
|
'image/x-cdr', |
||||
|
'zz-application/zz-winassoc-cdr', |
||||
|
], |
||||
|
'wma' => [ |
||||
|
'audio/x-ms-wma', |
||||
|
'video/x-ms-asf', |
||||
|
], |
||||
|
'jar' => [ |
||||
|
'application/java-archive', |
||||
|
'application/x-java-application', |
||||
|
'application/x-jar', |
||||
|
'application/x-compressed', |
||||
|
], |
||||
|
'svg' => [ |
||||
|
'image/svg+xml', |
||||
|
'application/xml', |
||||
|
'text/xml', |
||||
|
], |
||||
|
'vcf' => 'text/x-vcard', |
||||
|
'srt' => [ |
||||
|
'text/srt', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'vtt' => [ |
||||
|
'text/vtt', |
||||
|
'text/plain', |
||||
|
], |
||||
|
'ico' => [ |
||||
|
'image/x-icon', |
||||
|
'image/x-ico', |
||||
|
'image/vnd.microsoft.icon', |
||||
|
], |
||||
|
]; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
/** |
||||
|
* Attempts to determine the best mime type for the given file extension. |
||||
|
* |
||||
|
* @param string $extension |
||||
|
* |
||||
|
* @return string|null The mime type found, or none if unable to determine. |
||||
|
*/ |
||||
|
public static function guessTypeFromExtension(string $extension) |
||||
|
{ |
||||
|
$extension = trim(strtolower($extension), '. '); |
||||
|
|
||||
|
if (! array_key_exists($extension, static::$mimes)) |
||||
|
{ |
||||
|
return null; |
||||
|
} |
||||
|
|
||||
|
return is_array(static::$mimes[$extension]) ? static::$mimes[$extension][0] : static::$mimes[$extension]; |
||||
|
} |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
/** |
||||
|
* Attempts to determine the best file extension for a given mime type. |
||||
|
* |
||||
|
* @param string $type |
||||
|
* @param string $proposed_extension - default extension (in case there is more than one with the same mime type) |
||||
|
* |
||||
|
* @return string|null The extension determined, or null if unable to match. |
||||
|
*/ |
||||
|
public static function guessExtensionFromType(string $type, ?string $proposed_extension = null) |
||||
|
{ |
||||
|
$type = trim(strtolower($type), '. '); |
||||
|
|
||||
|
$proposed_extension = trim(strtolower($proposed_extension)); |
||||
|
|
||||
|
if (! is_null($proposed_extension) && array_key_exists($proposed_extension, static::$mimes) && in_array($type, is_string(static::$mimes[$proposed_extension]) ? [static::$mimes[$proposed_extension]] : static::$mimes[$proposed_extension])) |
||||
|
{ |
||||
|
return $proposed_extension; |
||||
|
} |
||||
|
|
||||
|
foreach (static::$mimes as $ext => $types) |
||||
|
{ |
||||
|
if (is_string($types) && $types === $type) |
||||
|
{ |
||||
|
return $ext; |
||||
|
} |
||||
|
else if (is_array($types) && in_array($type, $types)) |
||||
|
{ |
||||
|
return $ext; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
return null; |
||||
|
} |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
} |
@ -0,0 +1,67 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
// Cannot extend BaseConfig or looping resources occurs. |
||||
|
class Modules |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Auto-Discovery Enabled? |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If true, then auto-discovery will happen across all elements listed in |
||||
|
| $activeExplorers below. If false, no auto-discovery will happen at all, |
||||
|
| giving a slight performance boost. |
||||
|
*/ |
||||
|
public $enabled = true; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Auto-Discovery Within Composer Packages Enabled? |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| If true, then auto-discovery will happen across all namespaces loaded |
||||
|
| by Composer, as well as the namespaces configured locally. |
||||
|
*/ |
||||
|
public $discoverInComposer = true; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Auto-discover Rules |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Lists the aliases of all discovery classes that will be active |
||||
|
| and used during the current application request. If it is not |
||||
|
| listed here, only the base application elements will be used. |
||||
|
*/ |
||||
|
public $activeExplorers = [ |
||||
|
'events', |
||||
|
'registrars', |
||||
|
'routes', |
||||
|
'services', |
||||
|
]; |
||||
|
|
||||
|
/** |
||||
|
* Should the application auto-discover the requested resources. |
||||
|
* |
||||
|
* Valid values are: |
||||
|
* - events |
||||
|
* - registrars |
||||
|
* - routes |
||||
|
* - services |
||||
|
* |
||||
|
* @param string $alias |
||||
|
* |
||||
|
* @return boolean |
||||
|
*/ |
||||
|
public function shouldDiscover(string $alias) |
||||
|
{ |
||||
|
if (! $this->enabled) |
||||
|
{ |
||||
|
return false; |
||||
|
} |
||||
|
|
||||
|
$alias = strtolower($alias); |
||||
|
|
||||
|
return in_array($alias, $this->activeExplorers); |
||||
|
} |
||||
|
} |
@ -0,0 +1,35 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Pager extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Templates |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| Pagination links are rendered out using views to configure their |
||||
|
| appearance. This array contains aliases and the view names to |
||||
|
| use when rendering the links. |
||||
|
| |
||||
|
| Within each view, the Pager object will be available as $pager, |
||||
|
| and the desired group as $pagerGroup; |
||||
|
| |
||||
|
*/ |
||||
|
public $templates = [ |
||||
|
'default_full' => 'CodeIgniter\Pager\Views\default_full', |
||||
|
'default_simple' => 'CodeIgniter\Pager\Views\default_simple', |
||||
|
'default_head' => 'CodeIgniter\Pager\Views\default_head', |
||||
|
]; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Items Per Page |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| |
||||
|
| The default number of results shown in a single page. |
||||
|
| |
||||
|
*/ |
||||
|
public $perPage = 20; |
||||
|
} |
@ -0,0 +1,73 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
/** |
||||
|
* Holds the paths that are used by the system to |
||||
|
* locate the main directories, app, system, etc. |
||||
|
* Modifying these allows you to re-structure your application, |
||||
|
* share a system folder between multiple applications, and more. |
||||
|
* |
||||
|
* All paths are relative to the project's root folder. |
||||
|
*/ |
||||
|
|
||||
|
class Paths |
||||
|
{ |
||||
|
/* |
||||
|
*--------------------------------------------------------------- |
||||
|
* SYSTEM FOLDER NAME |
||||
|
*--------------------------------------------------------------- |
||||
|
* |
||||
|
* This variable must contain the name of your "system" folder. |
||||
|
* Include the path if the folder is not in the same directory |
||||
|
* as this file. |
||||
|
*/ |
||||
|
public $systemDirectory = __DIR__ . '/../../system'; |
||||
|
|
||||
|
/* |
||||
|
*--------------------------------------------------------------- |
||||
|
* APPLICATION FOLDER NAME |
||||
|
*--------------------------------------------------------------- |
||||
|
* |
||||
|
* If you want this front controller to use a different "app" |
||||
|
* folder than the default one you can set its name here. The folder |
||||
|
* can also be renamed or relocated anywhere on your getServer. If |
||||
|
* you do, use a full getServer path. For more info please see the user guide: |
||||
|
* http://codeigniter.com/user_guide/general/managing_apps.html |
||||
|
* |
||||
|
* NO TRAILING SLASH! |
||||
|
*/ |
||||
|
public $appDirectory = __DIR__ . '/..'; |
||||
|
|
||||
|
/* |
||||
|
* --------------------------------------------------------------- |
||||
|
* WRITABLE DIRECTORY NAME |
||||
|
* --------------------------------------------------------------- |
||||
|
* |
||||
|
* This variable must contain the name of your "writable" directory. |
||||
|
* The writable directory allows you to group all directories that |
||||
|
* need write permission to a single place that can be tucked away |
||||
|
* for maximum security, keeping it out of the app and/or |
||||
|
* system directories. |
||||
|
*/ |
||||
|
public $writableDirectory = __DIR__ . '/../../writable'; |
||||
|
|
||||
|
/* |
||||
|
* --------------------------------------------------------------- |
||||
|
* TESTS DIRECTORY NAME |
||||
|
* --------------------------------------------------------------- |
||||
|
* |
||||
|
* This variable must contain the name of your "tests" directory. |
||||
|
*/ |
||||
|
public $testsDirectory = __DIR__ . '/../../tests'; |
||||
|
|
||||
|
/* |
||||
|
* --------------------------------------------------------------- |
||||
|
* VIEW DIRECTORY NAME |
||||
|
* --------------------------------------------------------------- |
||||
|
* |
||||
|
* This variable must contain the name of the directory that |
||||
|
* contains the view files used by your application. By |
||||
|
* default this is in `app/Views`. This value |
||||
|
* is used when no value is provided to `Services::renderer()`. |
||||
|
*/ |
||||
|
public $viewDirectory = __DIR__ . '/../Views'; |
||||
|
} |
@ -0,0 +1,111 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use App\Controllers\GameController; |
||||
|
|
||||
|
/** |
||||
|
* -------------------------------------------------------------------- |
||||
|
* URI Routing |
||||
|
* -------------------------------------------------------------------- |
||||
|
* This file lets you re-map URI requests to specific controller functions. |
||||
|
* |
||||
|
* Typically there is a one-to-one relationship between a URL string |
||||
|
* and its corresponding controller class/method. The segments in a |
||||
|
* URL normally follow this pattern: |
||||
|
* |
||||
|
* example.com/class/method/id |
||||
|
* |
||||
|
* In some instances, however, you may want to remap this relationship |
||||
|
* so that a different class/function is called than the one |
||||
|
* corresponding to the URL. |
||||
|
*/ |
||||
|
|
||||
|
// Create a new instance of our RouteCollection class. |
||||
|
$routes = Services::routes(true); |
||||
|
|
||||
|
// Load the system's routing file first, so that the app and ENVIRONMENT |
||||
|
// can override as needed. |
||||
|
if (file_exists(SYSTEMPATH . 'Config/Routes.php')) |
||||
|
{ |
||||
|
require SYSTEMPATH . 'Config/Routes.php'; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Router Setup |
||||
|
* -------------------------------------------------------------------- |
||||
|
* The RouteCollection object allows you to modify the way that the |
||||
|
* Router works, by acting as a holder for it's configuration settings. |
||||
|
* The following methods can be called on the object to modify |
||||
|
* the default operations. |
||||
|
* |
||||
|
* $routes->defaultNamespace() |
||||
|
* |
||||
|
* Modifies the namespace that is added to a controller if it doesn't |
||||
|
* already have one. By default this is the global namespace (\). |
||||
|
* |
||||
|
* $routes->defaultController() |
||||
|
* |
||||
|
* Changes the name of the class used as a controller when the route |
||||
|
* points to a folder instead of a class. |
||||
|
* |
||||
|
* $routes->defaultMethod() |
||||
|
* |
||||
|
* Assigns the method inside the controller that is ran when the |
||||
|
* Router is unable to determine the appropriate method to run. |
||||
|
* |
||||
|
* $routes->setAutoRoute() |
||||
|
* |
||||
|
* Determines whether the Router will attempt to match URIs to |
||||
|
* Controllers when no specific route has been defined. If false, |
||||
|
* only routes that have been defined here will be available. |
||||
|
*/ |
||||
|
$routes->setDefaultNamespace('App\Controllers'); |
||||
|
$routes->setDefaultController('GameController'); |
||||
|
$routes->setDefaultMethod('index'); |
||||
|
$routes->setTranslateURIDashes(false); |
||||
|
$routes->set404Override(); |
||||
|
$routes->setAutoRoute(true); |
||||
|
|
||||
|
/** |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Route Definitions |
||||
|
* -------------------------------------------------------------------- |
||||
|
*/ |
||||
|
// We get a performance increase by specifying the default |
||||
|
// route since we don't have to scan directories. |
||||
|
$routes->get('/', 'GameController::index'); |
||||
|
|
||||
|
/** |
||||
|
* -------------------------------------------------------------------- |
||||
|
* GAME ROUTES |
||||
|
* -------------------------------------------------------------------- |
||||
|
*/ |
||||
|
$routes->add('createUser', 'GameController::createUser'); |
||||
|
$routes->add('createUser/(:segment)/(:segment)', 'GameController::createUser/$1/$2'); |
||||
|
$routes->add('endGame', 'GameController::endGame'); |
||||
|
$routes->add('getUser', 'GameController::getUser'); |
||||
|
$routes->add('getUser/(:segment)', 'GameController::getUser/$1'); |
||||
|
$routes->add('play', 'GameController::play'); |
||||
|
$routes->add('play/(:segment)', 'GameController::play/$1'); |
||||
|
$routes->add('setup', 'SetupController::setup'); |
||||
|
//$routes->add('testUser', 'GameController::testUser'); |
||||
|
$routes->add('testUser/(:segment)', 'GameController::testUser/$1'); |
||||
|
$routes->add('top10', 'GameController::top10'); |
||||
|
|
||||
|
/** |
||||
|
* -------------------------------------------------------------------- |
||||
|
* Additional Routing |
||||
|
* -------------------------------------------------------------------- |
||||
|
* |
||||
|
* There will often be times that you need additional routing and you |
||||
|
* need to it be able to override any defaults in this file. Environment |
||||
|
* based routes is one such time. require() additional route files here |
||||
|
* to make that happen. |
||||
|
* |
||||
|
* You will have access to the $routes object within that file without |
||||
|
* needing to reload it. |
||||
|
*/ |
||||
|
if (file_exists(APPPATH . 'Config/' . ENVIRONMENT . '/Routes.php')) |
||||
|
{ |
||||
|
require APPPATH . 'Config/' . ENVIRONMENT . '/Routes.php'; |
||||
|
} |
@ -0,0 +1,33 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\Services as CoreServices; |
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
require_once SYSTEMPATH . 'Config/Services.php'; |
||||
|
|
||||
|
/** |
||||
|
* Services Configuration file. |
||||
|
* |
||||
|
* Services are simply other classes/libraries that the system uses |
||||
|
* to do its job. This is used by CodeIgniter to allow the core of the |
||||
|
* framework to be swapped out easily without affecting the usage within |
||||
|
* the rest of your application. |
||||
|
* |
||||
|
* This file holds any application-specific services, or service overrides |
||||
|
* that you might need. An example has been included with the general |
||||
|
* method format you should use for your service methods. For more examples, |
||||
|
* see the core Services file at system/Config/Services.php. |
||||
|
*/ |
||||
|
class Services extends CoreServices |
||||
|
{ |
||||
|
|
||||
|
// public static function example($getShared = true) |
||||
|
// { |
||||
|
// if ($getShared) |
||||
|
// { |
||||
|
// return static::getSharedInstance('example'); |
||||
|
// } |
||||
|
// |
||||
|
// return new \CodeIgniter\Example(); |
||||
|
// } |
||||
|
} |
@ -0,0 +1,68 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class Toolbar extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Debug Toolbar |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| The Debug Toolbar provides a way to see information about the performance |
||||
|
| and state of your application during that page display. By default it will |
||||
|
| NOT be displayed under production environments, and will only display if |
||||
|
| CI_DEBUG is true, since if it's not, there's not much to display anyway. |
||||
|
| |
||||
|
| toolbarMaxHistory = Number of history files, 0 for none or -1 for unlimited |
||||
|
| |
||||
|
*/ |
||||
|
public $collectors = [ |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Timers::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Database::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Logs::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Views::class, |
||||
|
// \CodeIgniter\Debug\Toolbar\Collectors\Cache::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Files::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Routes::class, |
||||
|
\CodeIgniter\Debug\Toolbar\Collectors\Events::class, |
||||
|
]; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Max History |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| The Toolbar allows you to view recent requests that have been made to |
||||
|
| the application while the toolbar is active. This allows you to quickly |
||||
|
| view and compare multiple requests. |
||||
|
| |
||||
|
| $maxHistory sets a limit on the number of past requests that are stored, |
||||
|
| helping to conserve file space used to store them. You can set it to |
||||
|
| 0 (zero) to not have any history stored, or -1 for unlimited history. |
||||
|
| |
||||
|
*/ |
||||
|
public $maxHistory = 20; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Toolbar Views Path |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| The full path to the the views that are used by the toolbar. |
||||
|
| MUST have a trailing slash. |
||||
|
| |
||||
|
*/ |
||||
|
public $viewsPath = SYSTEMPATH . 'Debug/Toolbar/Views/'; |
||||
|
|
||||
|
/* |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| Max Queries |
||||
|
|-------------------------------------------------------------------------- |
||||
|
| If the Database Collector is enabled, it will log every query that the |
||||
|
| the system generates so they can be displayed on the toolbar's timeline |
||||
|
| and in the query log. This can lead to memory issues in some instances |
||||
|
| with hundreds of queries. |
||||
|
| |
||||
|
| $maxQueries defines the maximum amount of queries that will be stored. |
||||
|
| |
||||
|
*/ |
||||
|
public $maxQueries = 100; |
||||
|
} |
@ -0,0 +1,218 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
use CodeIgniter\Config\BaseConfig; |
||||
|
|
||||
|
class UserAgents extends BaseConfig |
||||
|
{ |
||||
|
/* |
||||
|
| ------------------------------------------------------------------- |
||||
|
| USER AGENT TYPES |
||||
|
| ------------------------------------------------------------------- |
||||
|
| This file contains four arrays of user agent data. It is used by the |
||||
|
| User Agent Class to help identify browser, platform, robot, and |
||||
|
| mobile device data. The array keys are used to identify the device |
||||
|
| and the array values are used to set the actual name of the item. |
||||
|
*/ |
||||
|
public $platforms = [ |
||||
|
'windows nt 10.0' => 'Windows 10', |
||||
|
'windows nt 6.3' => 'Windows 8.1', |
||||
|
'windows nt 6.2' => 'Windows 8', |
||||
|
'windows nt 6.1' => 'Windows 7', |
||||
|
'windows nt 6.0' => 'Windows Vista', |
||||
|
'windows nt 5.2' => 'Windows 2003', |
||||
|
'windows nt 5.1' => 'Windows XP', |
||||
|
'windows nt 5.0' => 'Windows 2000', |
||||
|
'windows nt 4.0' => 'Windows NT 4.0', |
||||
|
'winnt4.0' => 'Windows NT 4.0', |
||||
|
'winnt 4.0' => 'Windows NT', |
||||
|
'winnt' => 'Windows NT', |
||||
|
'windows 98' => 'Windows 98', |
||||
|
'win98' => 'Windows 98', |
||||
|
'windows 95' => 'Windows 95', |
||||
|
'win95' => 'Windows 95', |
||||
|
'windows phone' => 'Windows Phone', |
||||
|
'windows' => 'Unknown Windows OS', |
||||
|
'android' => 'Android', |
||||
|
'blackberry' => 'BlackBerry', |
||||
|
'iphone' => 'iOS', |
||||
|
'ipad' => 'iOS', |
||||
|
'ipod' => 'iOS', |
||||
|
'os x' => 'Mac OS X', |
||||
|
'ppc mac' => 'Power PC Mac', |
||||
|
'freebsd' => 'FreeBSD', |
||||
|
'ppc' => 'Macintosh', |
||||
|
'linux' => 'Linux', |
||||
|
'debian' => 'Debian', |
||||
|
'sunos' => 'Sun Solaris', |
||||
|
'beos' => 'BeOS', |
||||
|
'apachebench' => 'ApacheBench', |
||||
|
'aix' => 'AIX', |
||||
|
'irix' => 'Irix', |
||||
|
'osf' => 'DEC OSF', |
||||
|
'hp-ux' => 'HP-UX', |
||||
|
'netbsd' => 'NetBSD', |
||||
|
'bsdi' => 'BSDi', |
||||
|
'openbsd' => 'OpenBSD', |
||||
|
'gnu' => 'GNU/Linux', |
||||
|
'unix' => 'Unknown Unix OS', |
||||
|
'symbian' => 'Symbian OS', |
||||
|
]; |
||||
|
|
||||
|
// The order of this array should NOT be changed. Many browsers return |
||||
|
// multiple browser types so we want to identify the sub-type first. |
||||
|
public $browsers = [ |
||||
|
'OPR' => 'Opera', |
||||
|
'Flock' => 'Flock', |
||||
|
'Edge' => 'Spartan', |
||||
|
'Chrome' => 'Chrome', |
||||
|
// Opera 10+ always reports Opera/9.80 and appends Version/<real version> to the user agent string |
||||
|
'Opera.*?Version' => 'Opera', |
||||
|
'Opera' => 'Opera', |
||||
|
'MSIE' => 'Internet Explorer', |
||||
|
'Internet Explorer' => 'Internet Explorer', |
||||
|
'Trident.* rv' => 'Internet Explorer', |
||||
|
'Shiira' => 'Shiira', |
||||
|
'Firefox' => 'Firefox', |
||||
|
'Chimera' => 'Chimera', |
||||
|
'Phoenix' => 'Phoenix', |
||||
|
'Firebird' => 'Firebird', |
||||
|
'Camino' => 'Camino', |
||||
|
'Netscape' => 'Netscape', |
||||
|
'OmniWeb' => 'OmniWeb', |
||||
|
'Safari' => 'Safari', |
||||
|
'Mozilla' => 'Mozilla', |
||||
|
'Konqueror' => 'Konqueror', |
||||
|
'icab' => 'iCab', |
||||
|
'Lynx' => 'Lynx', |
||||
|
'Links' => 'Links', |
||||
|
'hotjava' => 'HotJava', |
||||
|
'amaya' => 'Amaya', |
||||
|
'IBrowse' => 'IBrowse', |
||||
|
'Maxthon' => 'Maxthon', |
||||
|
'Ubuntu' => 'Ubuntu Web Browser', |
||||
|
'Vivaldi' => 'Vivaldi', |
||||
|
]; |
||||
|
|
||||
|
public $mobiles = [ |
||||
|
// legacy array, old values commented out |
||||
|
'mobileexplorer' => 'Mobile Explorer', |
||||
|
// 'openwave' => 'Open Wave', |
||||
|
// 'opera mini' => 'Opera Mini', |
||||
|
// 'operamini' => 'Opera Mini', |
||||
|
// 'elaine' => 'Palm', |
||||
|
'palmsource' => 'Palm', |
||||
|
// 'digital paths' => 'Palm', |
||||
|
// 'avantgo' => 'Avantgo', |
||||
|
// 'xiino' => 'Xiino', |
||||
|
'palmscape' => 'Palmscape', |
||||
|
// 'nokia' => 'Nokia', |
||||
|
// 'ericsson' => 'Ericsson', |
||||
|
// 'blackberry' => 'BlackBerry', |
||||
|
// 'motorola' => 'Motorola' |
||||
|
|
||||
|
// Phones and Manufacturers |
||||
|
'motorola' => 'Motorola', |
||||
|
'nokia' => 'Nokia', |
||||
|
'palm' => 'Palm', |
||||
|
'iphone' => 'Apple iPhone', |
||||
|
'ipad' => 'iPad', |
||||
|
'ipod' => 'Apple iPod Touch', |
||||
|
'sony' => 'Sony Ericsson', |
||||
|
'ericsson' => 'Sony Ericsson', |
||||
|
'blackberry' => 'BlackBerry', |
||||
|
'cocoon' => 'O2 Cocoon', |
||||
|
'blazer' => 'Treo', |
||||
|
'lg' => 'LG', |
||||
|
'amoi' => 'Amoi', |
||||
|
'xda' => 'XDA', |
||||
|
'mda' => 'MDA', |
||||
|
'vario' => 'Vario', |
||||
|
'htc' => 'HTC', |
||||
|
'samsung' => 'Samsung', |
||||
|
'sharp' => 'Sharp', |
||||
|
'sie-' => 'Siemens', |
||||
|
'alcatel' => 'Alcatel', |
||||
|
'benq' => 'BenQ', |
||||
|
'ipaq' => 'HP iPaq', |
||||
|
'mot-' => 'Motorola', |
||||
|
'playstation portable' => 'PlayStation Portable', |
||||
|
'playstation 3' => 'PlayStation 3', |
||||
|
'playstation vita' => 'PlayStation Vita', |
||||
|
'hiptop' => 'Danger Hiptop', |
||||
|
'nec-' => 'NEC', |
||||
|
'panasonic' => 'Panasonic', |
||||
|
'philips' => 'Philips', |
||||
|
'sagem' => 'Sagem', |
||||
|
'sanyo' => 'Sanyo', |
||||
|
'spv' => 'SPV', |
||||
|
'zte' => 'ZTE', |
||||
|
'sendo' => 'Sendo', |
||||
|
'nintendo dsi' => 'Nintendo DSi', |
||||
|
'nintendo ds' => 'Nintendo DS', |
||||
|
'nintendo 3ds' => 'Nintendo 3DS', |
||||
|
'wii' => 'Nintendo Wii', |
||||
|
'open web' => 'Open Web', |
||||
|
'openweb' => 'OpenWeb', |
||||
|
|
||||
|
// Operating Systems |
||||
|
'android' => 'Android', |
||||
|
'symbian' => 'Symbian', |
||||
|
'SymbianOS' => 'SymbianOS', |
||||
|
'elaine' => 'Palm', |
||||
|
'series60' => 'Symbian S60', |
||||
|
'windows ce' => 'Windows CE', |
||||
|
|
||||
|
// Browsers |
||||
|
'obigo' => 'Obigo', |
||||
|
'netfront' => 'Netfront Browser', |
||||
|
'openwave' => 'Openwave Browser', |
||||
|
'mobilexplorer' => 'Mobile Explorer', |
||||
|
'operamini' => 'Opera Mini', |
||||
|
'opera mini' => 'Opera Mini', |
||||
|
'opera mobi' => 'Opera Mobile', |
||||
|
'fennec' => 'Firefox Mobile', |
||||
|
|
||||
|
// Other |
||||
|
'digital paths' => 'Digital Paths', |
||||
|
'avantgo' => 'AvantGo', |
||||
|
'xiino' => 'Xiino', |
||||
|
'novarra' => 'Novarra Transcoder', |
||||
|
'vodafone' => 'Vodafone', |
||||
|
'docomo' => 'NTT DoCoMo', |
||||
|
'o2' => 'O2', |
||||
|
|
||||
|
// Fallback |
||||
|
'mobile' => 'Generic Mobile', |
||||
|
'wireless' => 'Generic Mobile', |
||||
|
'j2me' => 'Generic Mobile', |
||||
|
'midp' => 'Generic Mobile', |
||||
|
'cldc' => 'Generic Mobile', |
||||
|
'up.link' => 'Generic Mobile', |
||||
|
'up.browser' => 'Generic Mobile', |
||||
|
'smartphone' => 'Generic Mobile', |
||||
|
'cellphone' => 'Generic Mobile', |
||||
|
]; |
||||
|
|
||||
|
// There are hundreds of bots but these are the most common. |
||||
|
public $robots = [ |
||||
|
'googlebot' => 'Googlebot', |
||||
|
'msnbot' => 'MSNBot', |
||||
|
'baiduspider' => 'Baiduspider', |
||||
|
'bingbot' => 'Bing', |
||||
|
'slurp' => 'Inktomi Slurp', |
||||
|
'yahoo' => 'Yahoo', |
||||
|
'ask jeeves' => 'Ask Jeeves', |
||||
|
'fastcrawler' => 'FastCrawler', |
||||
|
'infoseek' => 'InfoSeek Robot 1.0', |
||||
|
'lycos' => 'Lycos', |
||||
|
'yandex' => 'YandexBot', |
||||
|
'mediapartners-google' => 'MediaPartners Google', |
||||
|
'CRAZYWEBCRAWLER' => 'Crazy Webcrawler', |
||||
|
'adsbot-google' => 'AdsBot Google', |
||||
|
'feedfetcher-google' => 'Feedfetcher Google', |
||||
|
'curious george' => 'Curious George', |
||||
|
'ia_archiver' => 'Alexa Crawler', |
||||
|
'MJ12bot' => 'Majestic-12', |
||||
|
'Uptimebot' => 'Uptimebot', |
||||
|
]; |
||||
|
} |
@ -0,0 +1,36 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
class Validation |
||||
|
{ |
||||
|
//-------------------------------------------------------------------- |
||||
|
// Setup |
||||
|
//-------------------------------------------------------------------- |
||||
|
|
||||
|
/** |
||||
|
* Stores the classes that contain the |
||||
|
* rules that are available. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public $ruleSets = [ |
||||
|
\CodeIgniter\Validation\Rules::class, |
||||
|
\CodeIgniter\Validation\FormatRules::class, |
||||
|
\CodeIgniter\Validation\FileRules::class, |
||||
|
\CodeIgniter\Validation\CreditCardRules::class, |
||||
|
]; |
||||
|
|
||||
|
/** |
||||
|
* Specifies the views that are used to display the |
||||
|
* errors. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
public $templates = [ |
||||
|
'list' => 'CodeIgniter\Validation\Views\list', |
||||
|
'single' => 'CodeIgniter\Validation\Views\single', |
||||
|
]; |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
// Rules |
||||
|
//-------------------------------------------------------------------- |
||||
|
} |
@ -0,0 +1,34 @@ |
|||||
|
<?php namespace Config; |
||||
|
|
||||
|
class View extends \CodeIgniter\Config\View |
||||
|
{ |
||||
|
/** |
||||
|
* When false, the view method will clear the data between each |
||||
|
* call. This keeps your data safe and ensures there is no accidental |
||||
|
* leaking between calls, so you would need to explicitly pass the data |
||||
|
* to each view. You might prefer to have the data stick around between |
||||
|
* calls so that it is available to all views. If that is the case, |
||||
|
* set $saveData to true. |
||||
|
*/ |
||||
|
public $saveData = true; |
||||
|
|
||||
|
/** |
||||
|
* Parser Filters map a filter name with any PHP callable. When the |
||||
|
* Parser prepares a variable for display, it will chain it |
||||
|
* through the filters in the order defined, inserting any parameters. |
||||
|
* To prevent potential abuse, all filters MUST be defined here |
||||
|
* in order for them to be available for use within the Parser. |
||||
|
* |
||||
|
* Examples: |
||||
|
* { title|esc(js) } |
||||
|
* { created_on|date(Y-m-d)|esc(attr) } |
||||
|
*/ |
||||
|
public $filters = []; |
||||
|
|
||||
|
/** |
||||
|
* Parser Plugins provide a way to extend the functionality provided |
||||
|
* by the core Parser by creating aliases that will be replaced with |
||||
|
* any callable. Can be single or tag pair. |
||||
|
*/ |
||||
|
public $plugins = []; |
||||
|
} |
@ -0,0 +1,46 @@ |
|||||
|
<?php |
||||
|
namespace App\Controllers; |
||||
|
|
||||
|
/** |
||||
|
* Class BaseController |
||||
|
* |
||||
|
* BaseController provides a convenient place for loading components |
||||
|
* and performing functions that are needed by all your controllers. |
||||
|
* Extend this class in any new controllers: |
||||
|
* class Home extends BaseController |
||||
|
* |
||||
|
* For security be sure to declare any new methods as protected or private. |
||||
|
* |
||||
|
* @package CodeIgniter |
||||
|
*/ |
||||
|
|
||||
|
use CodeIgniter\Controller; |
||||
|
|
||||
|
class BaseController extends Controller |
||||
|
{ |
||||
|
|
||||
|
/** |
||||
|
* An array of helpers to be loaded automatically upon |
||||
|
* class instantiation. These helpers will be available |
||||
|
* to all other controllers that extend BaseController. |
||||
|
* |
||||
|
* @var array |
||||
|
*/ |
||||
|
protected $helpers = []; |
||||
|
|
||||
|
/** |
||||
|
* Constructor. |
||||
|
*/ |
||||
|
public function initController(\CodeIgniter\HTTP\RequestInterface $request, \CodeIgniter\HTTP\ResponseInterface $response, \Psr\Log\LoggerInterface $logger) |
||||
|
{ |
||||
|
// Do Not Edit This Line |
||||
|
parent::initController($request, $response, $logger); |
||||
|
|
||||
|
//-------------------------------------------------------------------- |
||||
|
// Preload any models, libraries, etc, here. |
||||
|
//-------------------------------------------------------------------- |
||||
|
// E.g.: |
||||
|
// $this->session = \Config\Services::session(); |
||||
|
} |
||||
|
|
||||
|
} |
@ -0,0 +1,562 @@ |
|||||
|
<?php namespace App\Controllers; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/Controllers/GameController.php |
||||
|
* @package App\Controllers |
||||
|
* @description |
||||
|
* Main Controller for Game. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
use App\Libraries\Location; |
||||
|
use App\Models\UserModel; |
||||
|
use App\Models\PlayModel; |
||||
|
use App\Models\LogModel; |
||||
|
|
||||
|
class GameController extends BaseController |
||||
|
{ |
||||
|
private $session; |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* GameController constructor. |
||||
|
*/ |
||||
|
public function __construct() |
||||
|
{ |
||||
|
$this->session = session(); |
||||
|
if (empty($this->session->get('ip')) && empty($this->session->get('UserID'))) |
||||
|
{ |
||||
|
$this->CreateSession(); |
||||
|
$this->CreateLogRecord(); |
||||
|
return redirect()->route('/'); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
return redirect()->route('play'); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method index |
||||
|
* @description |
||||
|
* Main page for game, Start/Home Page. |
||||
|
*/ |
||||
|
public function index() |
||||
|
{ |
||||
|
$HeaderData = $this->getHeaderData(); |
||||
|
echo view('inc/head'); |
||||
|
echo view('inc/header', $HeaderData); |
||||
|
echo view('game'); |
||||
|
echo view('inc/footer'); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method createUser |
||||
|
* @description |
||||
|
* Creates user for game play. |
||||
|
* @param $UserName |
||||
|
* @param $UserID |
||||
|
* |
||||
|
* @return \CodeIgniter\HTTP\RedirectResponse |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
public function createUser($UserName, $UserID) |
||||
|
{ |
||||
|
$UserName = esc($UserName); |
||||
|
$UserID = esc($UserID); |
||||
|
$dbUsers = new UserModel(); |
||||
|
|
||||
|
// Validate User Name |
||||
|
if (!$this->validateUserName($UserName)) return redirect()->to(base_url() . '/getUser'); |
||||
|
$UserID = $this->saveUserData($UserID, $UserName); |
||||
|
$UserData = $dbUsers->find($UserID); |
||||
|
// Add user to the Session |
||||
|
$data = |
||||
|
[ |
||||
|
'UserID' => $UserID, |
||||
|
'UserName' => $UserName, |
||||
|
'Wins' => $UserData['Wins'], |
||||
|
'Loses' => $UserData['Loses'], |
||||
|
'Ties' => $UserData['Ties'] |
||||
|
]; |
||||
|
$this->session->set($data); |
||||
|
// Pass off to PLAY() |
||||
|
return redirect()->route('play'); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method endGame |
||||
|
* @description |
||||
|
* Destroys Session and sends them back to Home Page. |
||||
|
* @return \CodeIgniter\HTTP\RedirectResponse |
||||
|
*/ |
||||
|
public function endGame() |
||||
|
{ |
||||
|
// Close Session |
||||
|
$this->session->destroy(); |
||||
|
// Goto Index page |
||||
|
return redirect()->route('/'); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method getUser |
||||
|
* @description |
||||
|
* Prompt Screen to get user name for game play. |
||||
|
*/ |
||||
|
public function getUser() |
||||
|
{ |
||||
|
$getUserData = ['UserName' => $this->session->getFlashdata('UserName'), 'ErrorCode' => $this->session->getFlashdata('ErrorCode')]; |
||||
|
$HeaderData = $this->getHeaderData(); |
||||
|
echo view('inc/head'); |
||||
|
echo view('inc/header', $HeaderData); |
||||
|
echo view('getUser', $getUserData); |
||||
|
echo view('inc/footer'); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method play |
||||
|
* @description |
||||
|
* Main Play Page/Function Logic. |
||||
|
* |
||||
|
* @param null $PlayerPick |
||||
|
* @todo REFACTOR GAME PLAY!! |
||||
|
* |
||||
|
* @return \CodeIgniter\HTTP\RedirectResponse|false|string |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
public function play($PlayerPick = null) |
||||
|
{ |
||||
|
$UserID = $this->session->UserID; |
||||
|
|
||||
|
if ($PlayerPick) |
||||
|
{ |
||||
|
$W = 0; // Win |
||||
|
$L = 0; // Lose |
||||
|
$T = 0; // Tie |
||||
|
$ComputerPick = $this->ComputerPick(); |
||||
|
$textResult = ''; |
||||
|
$TextResults = |
||||
|
[ |
||||
|
'RL' => 'Rock Crushes Lizard!', |
||||
|
'RS' => 'Rock Crushes Scissors!', |
||||
|
'PR' => 'Paper Covers Rock!', |
||||
|
'PS' => 'Paper Disproves Spock!', |
||||
|
'SP' => 'Scissors Cuts Paper!', |
||||
|
'SL' => 'Scissors Decapitates Lizard!', |
||||
|
'LS' => 'Lizard Poisons Spock!', |
||||
|
'LP' => 'Lizard Eats Paper!', |
||||
|
'SS' => 'Spock Smashes Scissors!', |
||||
|
'SR' => 'Spock Vaporizes Rock!', |
||||
|
'TIE' => 'No One Wins This Time.', |
||||
|
'DRAW' => 'Danger, Danger Will Robinson, that does not compute!', |
||||
|
]; |
||||
|
|
||||
|
/** GAME LOGIC */ |
||||
|
switch(strtoupper($PlayerPick)) |
||||
|
{ |
||||
|
case 'ROCK': |
||||
|
switch(strtoupper($ComputerPick)) |
||||
|
{ |
||||
|
case 'ROCK': $textResult = 'TIE'; $W = 0; $L = 0; $T = 1; break; |
||||
|
case 'PAPER': $textResult = 'PR'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'SCISSORS': $textResult = 'RS'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'LIZARD': $textResult = 'RL'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'SPOCK': $textResult = 'SR'; $W = 0; $L = 1; $T = 0; break; |
||||
|
default: $textResult = 'DRAW'; $W = 0; $L = 0; $T = 0; |
||||
|
} |
||||
|
break; |
||||
|
case 'PAPER': |
||||
|
switch(strtoupper($ComputerPick)) |
||||
|
{ |
||||
|
case 'ROCK': $textResult = 'PR'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'PAPER': $textResult = 'TIE'; $W = 0; $L = 0; $T = 1; break; |
||||
|
case 'SCISSORS': $textResult = 'SP'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'LIZARD': $textResult = 'LP'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'SPOCK': $textResult = 'PS'; $W = 1; $L = 0; $T = 0; break; |
||||
|
default: $textResult = 'DRAW'; $W = 0; $L = 0; $T = 0; |
||||
|
} |
||||
|
break; |
||||
|
case 'SCISSORS': |
||||
|
switch(strtoupper($ComputerPick)) |
||||
|
{ |
||||
|
case 'ROCK': $textResult = 'RS'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'PAPER': $textResult = 'SP'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'SCISSORS': $textResult = 'TIE'; $W = 0; $L = 0; $T = 1; break; |
||||
|
case 'LIZARD': $textResult = 'SL'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'SPOCK': $textResult = 'SS'; $W = 0; $L = 1; $T = 0; break; |
||||
|
default: $textResult = 'DRAW'; $W = 0; $L = 0; $T = 0; |
||||
|
} |
||||
|
break; |
||||
|
case 'LIZARD': |
||||
|
switch(strtoupper($ComputerPick)) |
||||
|
{ |
||||
|
case 'ROCK': $textResult = 'RL'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'PAPER': $textResult = 'LP'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'SCISSORS': $textResult = 'SL'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'LIZARD': $textResult = 'TIE'; $W = 0; $L = 0; $T = 1; break; |
||||
|
case 'SPOCK': $textResult = 'LS'; $W = 1; $L = 0; $T = 0; break; |
||||
|
default: $textResult = 'DRAW'; $W = 0; $L = 0; $T = 0; |
||||
|
} |
||||
|
break; |
||||
|
case 'SPOCK': |
||||
|
switch(strtoupper($ComputerPick)) |
||||
|
{ |
||||
|
case 'ROCK': $textResult = 'SR'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'PAPER': $textResult = 'PS'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'SCISSORS': $textResult = 'SS'; $W = 1; $L = 0; $T = 0; break; |
||||
|
case 'LIZARD': $textResult = 'LS'; $W = 0; $L = 1; $T = 0; break; |
||||
|
case 'SPOCK': $textResult = 'TIE'; $W = 0; $L = 0; $T = 1; break; |
||||
|
default: $textResult = 'DRAW'; $W = 0; $L = 0; $T = 0; |
||||
|
} |
||||
|
break; |
||||
|
default: |
||||
|
// TODO: SOME RETURN ERROR GOES HERE |
||||
|
// AS WE SHOULD NEVER GET HERE... |
||||
|
} |
||||
|
|
||||
|
// Text for Play Result of who Won, Lost or Tied. |
||||
|
if ($W === 1 && $L === 0 && $T === 0) $PlayResult = 'WINNER'; |
||||
|
elseif ($W === 0 && $L === 1 && $T === 0) $PlayResult = 'LOSER'; |
||||
|
elseif ($W === 0 && $L === 0 && $T === 1) $PlayResult = 'TIE'; |
||||
|
else $PlayResult = 'DRAW'; |
||||
|
|
||||
|
$this->addPlay( $this->session->UserID, $this->session->UserName, $this->session->ip, $PlayerPick, $ComputerPick, $PlayResult); |
||||
|
|
||||
|
$data = |
||||
|
[ |
||||
|
'Wins' => $this->session->Wins + $W, |
||||
|
'Loses' => $this->session->Loses + $L, |
||||
|
'Ties' => $this->session->Ties + $T, |
||||
|
]; |
||||
|
$this->session->set($data); |
||||
|
$this->updateDBCounts($this->session->UserID, $this->session->Wins, $this->session->Loses, $this->session->Ties); |
||||
|
|
||||
|
//////////////////////////////////////////////////////////////////////////////////////////////////////// |
||||
|
|
||||
|
$data = |
||||
|
[ |
||||
|
'PlayerPick' => $PlayerPick, |
||||
|
'ComputerPick' => $ComputerPick, |
||||
|
'Result' => $PlayResult, |
||||
|
'ResultText' => $TextResults[$textResult], |
||||
|
'Wins' => $this->session->Wins, |
||||
|
'Loses' => $this->session->Loses, |
||||
|
'Ties' => $this->session->Ties, |
||||
|
]; |
||||
|
return json_encode($data); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
$playData = |
||||
|
[ |
||||
|
'UserID' => $this->session->UserID, |
||||
|
'UserName' => $this->session->UserName, |
||||
|
'Wins' => $this->session->Wins, |
||||
|
'Loses' => $this->session->Loses, |
||||
|
'Ties' => $this->session->Ties, |
||||
|
]; |
||||
|
|
||||
|
if (empty($UserID)) |
||||
|
{ |
||||
|
return redirect()->to(base_url() . '/getUser'); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
$HeaderData = $this->getHeaderData(); |
||||
|
echo view('inc/head'); |
||||
|
echo view('inc/header', $HeaderData); |
||||
|
echo view('play', $playData); |
||||
|
echo view('inc/footer'); |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
************************************************************************************************************* |
||||
|
* @method testUser |
||||
|
* @description |
||||
|
* Returns UserID from User Name if one exists else it will return a 0. |
||||
|
* |
||||
|
* @param $UserName |
||||
|
* |
||||
|
* @return string |
||||
|
*/ |
||||
|
public function testUser($UserName) |
||||
|
{ |
||||
|
// TODO: Have it compare more then name to equal the same |
||||
|
// if not the same country and city then its a new user |
||||
|
// and they should pick a different name, as this one |
||||
|
// belongs to someone else. This will keep stats correct! |
||||
|
return $this->getIDfromUserName($UserName); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method top10 |
||||
|
* @description |
||||
|
* Logic for the Top10 page. |
||||
|
*/ |
||||
|
public function top10() |
||||
|
{ |
||||
|
//Table Models |
||||
|
$dbUsers = new UserModel(); |
||||
|
$dbPlay = new PlayModel(); |
||||
|
// Queries |
||||
|
$TotalPlays = $dbPlay->query("SELECT COUNT(Result) AS Total FROM plays")->getRow(); |
||||
|
$TotalWinsPlayer = $dbPlay->query("SELECT COUNT(Result) AS Total FROM plays WHERE Result = 'WINNER'")->getRow(); |
||||
|
$TotalLosesPlayer = $dbPlay->query("SELECT COUNT(Result) AS Total FROM plays WHERE Result = 'LOSER'")->getRow(); |
||||
|
$TotalTiesPlayer = $dbPlay->query("SELECT COUNT(Result) AS Total FROM plays WHERE Result = 'TIE'")->getRow(); |
||||
|
// echo '##### RESULT: ' . $TotalsWinsPlayer->Total . ' #####'; |
||||
|
$Win10 = $dbUsers->select('UserName, Wins')->OrderBy('Wins', 'DESC')->findAll(10); |
||||
|
$Lose10 = $dbUsers->select('UserName, Loses')->OrderBy('Loses', 'DESC')->findAll(10); |
||||
|
$Tie10 = $dbUsers->select('UserName, Ties')->OrderBy('Ties', 'DESC')->findAll(10); |
||||
|
$PlayerPicks = $dbPlay->select('PlayerPick, COUNT(PlayerPick) AS Total')->groupBy('PlayerPick')->OrderBy('Total', 'DESC')->findAll(5); |
||||
|
$ComputerPicks = $dbPlay->select('ComputerPick, COUNT(PlayerPick) AS Total')->groupBy('ComputerPick')->OrderBy('Total', 'DESC')->findAll(5); |
||||
|
// Combine Results for View |
||||
|
$PageData = |
||||
|
[ |
||||
|
'Win10' => $Win10, |
||||
|
'Lose10' => $Lose10, |
||||
|
'Tie10' => $Tie10, |
||||
|
'PlayerPicks' => $PlayerPicks, |
||||
|
'ComputerPicks' => $ComputerPicks, |
||||
|
'TotalWinsPlayer' => $TotalWinsPlayer, |
||||
|
'TotalLosesPlayer' => $TotalLosesPlayer, |
||||
|
'TotalTiesPlayer' => $TotalTiesPlayer, |
||||
|
'TotalPlays' => $TotalPlays |
||||
|
]; |
||||
|
|
||||
|
$HeaderData = $this->getHeaderData(); |
||||
|
echo view('inc/head'); |
||||
|
echo view('inc/header', $HeaderData); |
||||
|
echo view('top10', $PageData); |
||||
|
echo view('inc/footer'); |
||||
|
} |
||||
|
|
||||
|
// ############################################################################################################# |
||||
|
// ### START OF PRIVATE FUNCTIONS |
||||
|
// ############################################################################################################# |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method addPlay |
||||
|
* @description |
||||
|
* Adds (Inserts) Game Play Results to the DB. |
||||
|
* |
||||
|
* @param $UserID |
||||
|
* @param $UserName |
||||
|
* @param $IP |
||||
|
* @param $PlayerPick |
||||
|
* @param $ComputerPick |
||||
|
* @param $Result |
||||
|
* |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
private function addPlay($UserID, $UserName, $IP, $PlayerPick, $ComputerPick, $Result) |
||||
|
{ |
||||
|
$dbPlay = new PlayModel(); |
||||
|
$data = |
||||
|
[ |
||||
|
'UserID' => $UserID, |
||||
|
'UserName' => $UserName, |
||||
|
'IP' => $IP, |
||||
|
'PlayerPick' => $PlayerPick, |
||||
|
'ComputerPick' => $ComputerPick, |
||||
|
'Result' => $Result |
||||
|
]; |
||||
|
$dbPlay->insert($data); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method ComputerPick |
||||
|
* @description |
||||
|
* Returns the Computers Pick/Choice. |
||||
|
* @return string |
||||
|
*/ |
||||
|
private function ComputerPick() |
||||
|
{ |
||||
|
mt_srand(crc32(microtime())); |
||||
|
$pick = mt_rand(0,4); |
||||
|
$ComputerPicks = array('Rock', 'Paper', 'Scissors', 'Lizard', 'Spock'); |
||||
|
return $ComputerPicks[$pick]; |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method CreateLogRecord |
||||
|
* @description |
||||
|
* Inserts a Log Record at start of New Session. |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
private function CreateLogRecord() |
||||
|
{ |
||||
|
$dbLog = new LogModel(); |
||||
|
$data = |
||||
|
[ |
||||
|
'IP' => $this->session->get('ip'), |
||||
|
'City' => $this->session->get('city'), |
||||
|
'State' => $this->session->get('region_name'), |
||||
|
'Country' => $this->session->get('country_name'), |
||||
|
]; |
||||
|
$dbLog->insert($data); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method CreateSession |
||||
|
* @description |
||||
|
* Creates a new session for start of Game Play. |
||||
|
*/ |
||||
|
private function CreateSession() |
||||
|
{ |
||||
|
$Location = new Location(); |
||||
|
$this->session->set($Location->Data); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method getPageName |
||||
|
* @description |
||||
|
* Returns the current page name, used for menu to show active page. |
||||
|
* @return string |
||||
|
*/ |
||||
|
private function getPageName() |
||||
|
{ |
||||
|
return $this->request->uri->getSegment(1); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method getHeaderData |
||||
|
* @description |
||||
|
* Creates array of header page data to pass into view. |
||||
|
* @return array |
||||
|
*/ |
||||
|
private function getHeaderData() |
||||
|
{ |
||||
|
$page = $this->getPageName(); |
||||
|
$data = |
||||
|
[ |
||||
|
'page' => $page, |
||||
|
]; |
||||
|
return $data; |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method getIDfromUserName |
||||
|
* @description |
||||
|
* Returns UserID from User Name if one exists else it will return a 0. |
||||
|
* |
||||
|
* @param $UserName |
||||
|
* |
||||
|
* @return string |
||||
|
*/ |
||||
|
private function getIDfromUserName($UserName) |
||||
|
{ |
||||
|
$UserName = esc($UserName); |
||||
|
$dbUsers = new UserModel(); |
||||
|
$row = $dbUsers->select('id')->where('UserName', $UserName)->findAll(1); |
||||
|
return (empty($row['0']['id'])) ? '0' : strval($row['0']['id']); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method saveUserData |
||||
|
* @description |
||||
|
* Either saves (Inserts) the new user, or it will save (Update) a current user in the DB. |
||||
|
* This will return the UserID once Updated/Inserted into the DB. |
||||
|
* |
||||
|
* @param $UserID |
||||
|
* @param $UserName |
||||
|
* |
||||
|
* @return string |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
private function saveUserData($UserID, $UserName) |
||||
|
{ |
||||
|
$dbUsers = new UserModel(); |
||||
|
if ($UserID !== '0') |
||||
|
{ |
||||
|
// UPDATE |
||||
|
$data = |
||||
|
[ |
||||
|
'id' => $UserID, |
||||
|
'IP' => $this->session->get('ip'), |
||||
|
]; |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
// ADD (Create) |
||||
|
$data = |
||||
|
[ |
||||
|
'UserName' => $UserName, |
||||
|
'Wins' => 0, |
||||
|
'Loses' => 0, |
||||
|
'Ties' => 0, |
||||
|
'IP' => $this->session->get('ip'), |
||||
|
'City' => $this->session->get('city'), |
||||
|
'State' => $this->session->get('region_name'), |
||||
|
'Country' => $this->session->get('country_name'), |
||||
|
'CountryCode' => $this->session->get('country_code'), |
||||
|
'FlagURL' => $this->session->get('flagUrl'), |
||||
|
]; |
||||
|
} |
||||
|
$dbUsers->save($data); |
||||
|
return $this->getIDfromUserName($UserName); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method updateDBCounts |
||||
|
* @description |
||||
|
* This will update user scores from game play. |
||||
|
* |
||||
|
* @param $UserID |
||||
|
* @param $Wins |
||||
|
* @param $Loses |
||||
|
* @param $Ties |
||||
|
* |
||||
|
* @throws \ReflectionException |
||||
|
*/ |
||||
|
private function updateDBCounts($UserID, $Wins, $Loses, $Ties) |
||||
|
{ |
||||
|
$dbUsers = new UserModel(); |
||||
|
$UserID = esc($UserID); |
||||
|
$Wins = esc($Wins); |
||||
|
$Loses = esc($Loses); |
||||
|
$Ties = esc($Ties); |
||||
|
|
||||
|
$data = |
||||
|
[ |
||||
|
'id' => $UserID, |
||||
|
'Wins' => $Wins, |
||||
|
'Loses' => $Loses, |
||||
|
'Ties' => $Ties, |
||||
|
]; |
||||
|
$dbUsers->save($data); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
************************************************************************************************************* |
||||
|
* @method validateUserName |
||||
|
* @description |
||||
|
* Backend user name validation. |
||||
|
* |
||||
|
* @param $UserName |
||||
|
* |
||||
|
* @return bool |
||||
|
*/ |
||||
|
private function validateUserName($UserName) |
||||
|
{ |
||||
|
$Valid = TRUE; |
||||
|
$validation = \Config\Services::validation(); |
||||
|
if (!$validation->check($UserName, 'required|regex_match[/^([0-9a-zA-Z-_@\.]*)$/]')) |
||||
|
{ |
||||
|
$data = |
||||
|
[ |
||||
|
'UserName' => $UserName, |
||||
|
'ErrorCode' => 'User Name can only contain characters: (a-z, A-Z, 0-9, - _ @ .) Only.' |
||||
|
]; |
||||
|
$this->session->setFlashdata($data); |
||||
|
$Valid = FALSE; |
||||
|
} |
||||
|
return $Valid; |
||||
|
} |
||||
|
} |
@ -0,0 +1,196 @@ |
|||||
|
<?php namespace App\Controllers; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/Controllers/SetupController.php |
||||
|
* @package App\Controllers |
||||
|
* @description |
||||
|
* Sets up the DB on first run if it does not exist. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
|
||||
|
class SetupController extends BaseController |
||||
|
{ |
||||
|
private $forge; |
||||
|
private $Error_Flag = FALSE; |
||||
|
|
||||
|
/** |
||||
|
* SetupController constructor. |
||||
|
*/ |
||||
|
public function __construct() |
||||
|
{ |
||||
|
$this->forge = \Config\Database::forge(); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method setup |
||||
|
* |
||||
|
* @description |
||||
|
* Class Page Call for setting up DB. |
||||
|
* This will attempt to create DB, tables and indexes for the Game using SQLite. |
||||
|
* Note: Make sure permissions are set correct on the app/Database directory so program |
||||
|
* can write DB to path. |
||||
|
*/ |
||||
|
public function setup() |
||||
|
{ |
||||
|
// Create new DB /////////////////////////////////////////////////////////////////////////////////////////// |
||||
|
if ($this->forge->createDatabase('game')) |
||||
|
echo 'Game Database created. <br>'; |
||||
|
else |
||||
|
{ |
||||
|
echo 'Error Creating Game DB! <br>'; |
||||
|
$this->Error_Flag = TRUE; |
||||
|
} |
||||
|
|
||||
|
// Build Log Table ///////////////////////////////////////////////////////////////////////////////////////// |
||||
|
if (is_object($this->BuildLogTable())) |
||||
|
echo '(Log) table was created in DB. <br>'; |
||||
|
else |
||||
|
{ |
||||
|
echo 'Error Creating (Log) Table! <br>'; |
||||
|
$this->Error_Flag = TRUE; |
||||
|
} |
||||
|
|
||||
|
// Build Play Table //////////////////////////////////////////////////////////////////////////////////////// |
||||
|
if (is_object($this->BuildPlayTable())) |
||||
|
echo '(Play) table was created in DB. <br>'; |
||||
|
else |
||||
|
{ |
||||
|
echo 'Error Creating (Play) Table! <br>'; |
||||
|
$this->Error_Flag = TRUE; |
||||
|
} |
||||
|
|
||||
|
// Build USER Table //////////////////////////////////////////////////////////////////////////////////////// |
||||
|
if (is_object($this->BuildUserTable())) |
||||
|
echo '(User) table was created in DB. <br>'; |
||||
|
else |
||||
|
{ |
||||
|
echo 'Error Creating (User) Table! <br>'; |
||||
|
$this->Error_Flag = TRUE; |
||||
|
} |
||||
|
|
||||
|
if ($this->Error_Flag) |
||||
|
{ |
||||
|
echo 'Errors while trying to create DB'; |
||||
|
exit; |
||||
|
} |
||||
|
else |
||||
|
echo 'Starting Game Page.'; |
||||
|
|
||||
|
return redirect('/', 'refresh'); |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* START OF PRIVATE FUNCTIONS |
||||
|
**************************************************************************************************************/ |
||||
|
|
||||
|
/** |
||||
|
* @method BuildLogTable |
||||
|
* @description |
||||
|
* Pulls in Log Table Fields & Indexes, then attempts to create Log Table |
||||
|
* @return mixed |
||||
|
*/ |
||||
|
private function BuildLogTable() |
||||
|
{ |
||||
|
$this->forge->addField($this->LogFields()); |
||||
|
return $this->forge->createTable('Log', TRUE); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method BuildPlayTable |
||||
|
* @description |
||||
|
* Pulls in Play Table Fields & Indexes, then attempts to create Play Table |
||||
|
* @return mixed |
||||
|
*/ |
||||
|
private function BuildPlayTable() |
||||
|
{ |
||||
|
$this->forge->addField($this->PlayFields()); |
||||
|
return $this->forge->createTable('plays', TRUE); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method BuildUserTable |
||||
|
* @description |
||||
|
* Pulls in User Table Fields & Indexes, then attempts to create User Table |
||||
|
* @return mixed |
||||
|
*/ |
||||
|
private function BuildUserTable() |
||||
|
{ |
||||
|
$this->forge->addField($this->UserFields()); |
||||
|
$this->forge->addKey('UserName', FALSE, TRUE); |
||||
|
return $this->forge->createTable('users', TRUE); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method LogFields |
||||
|
* @description |
||||
|
* Fields and Indexes, Structure for the Log Table |
||||
|
* @return array |
||||
|
*/ |
||||
|
private function LogFields() |
||||
|
{ |
||||
|
return $fields = |
||||
|
[ |
||||
|
'id' => ['type' => 'int', 'auto_increment' => TRUE, ], |
||||
|
'IP' => ['type' => 'text', ], |
||||
|
'City' => ['type' => 'text', ], |
||||
|
'State' => ['type' => 'text', ], |
||||
|
'Country' => ['type' => 'text', ], |
||||
|
'DateTime' => ['type' => 'date', 'null' => TRUE, ], |
||||
|
]; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method PlayFields |
||||
|
* @description |
||||
|
* Fields and Indexes, Structure for the Play Table |
||||
|
* @return array |
||||
|
*/ |
||||
|
private function PlayFields() |
||||
|
{ |
||||
|
return $fields = |
||||
|
[ |
||||
|
'id' => ['type' => 'int', 'auto_increment' => TRUE, ], |
||||
|
'UserID' => ['type' => 'text', ], |
||||
|
'UserName' => ['type' => 'text', ], |
||||
|
'IP' => ['type' => 'text', ], |
||||
|
'PlayerPick' => ['type' => 'text', ], |
||||
|
'ComputerPick' => ['type' => 'text', ], |
||||
|
'Result' => ['type' => 'text', ], |
||||
|
'DateTime' => ['type' => 'date', 'null' => TRUE, ], |
||||
|
]; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* @method UserFields |
||||
|
* @description |
||||
|
* Fields and Indexes, Structure for the User Table |
||||
|
* @return array |
||||
|
*/ |
||||
|
private function UserFields() |
||||
|
{ |
||||
|
return $fields = |
||||
|
[ |
||||
|
'id' => ['type' => 'int', 'auto_increment' => TRUE, ], |
||||
|
'UserName' => ['type' => 'text', ], |
||||
|
'Wins' => ['type' => 'int', 'default' => 0, ], |
||||
|
'Loses' => ['type' => 'int', 'default' => 0, ], |
||||
|
'Ties' => ['type' => 'int', 'default' => 0, ], |
||||
|
'IP' => ['type' => 'text', ], |
||||
|
'City' => ['type' => 'text', ], |
||||
|
'State' => ['type' => 'text', ], |
||||
|
'Country' => ['type' => 'text', ], |
||||
|
'CountryCode' => ['type' => 'text', ], |
||||
|
'FlagURL' => ['type' => 'text', ], |
||||
|
'DateCreated' => ['type' => 'date', 'null' => TRUE, ], |
||||
|
'DateUpdated' => ['type' => 'date', 'null' => TRUE, ], |
||||
|
'DateDeleted' => ['type' => 'date', 'null' => TRUE, ], |
||||
|
]; |
||||
|
} |
||||
|
} |
@ -0,0 +1,41 @@ |
|||||
|
create table countries |
||||
|
( |
||||
|
id INTEGER |
||||
|
primary key autoincrement, |
||||
|
Country text not null, |
||||
|
CountryCode text not null, |
||||
|
FlagURL text not null, |
||||
|
Wins int default 0 not null, |
||||
|
Loses int default 0 not null, |
||||
|
DateCreated date, |
||||
|
DateUpdated date, |
||||
|
DateDeleted date |
||||
|
); |
||||
|
|
||||
|
create unique index countries_Country |
||||
|
on countries (Country); |
||||
|
|
||||
|
create unique index countries_CountryCode |
||||
|
on countries (CountryCode); |
||||
|
|
||||
|
# --------------------------------------- |
||||
|
|
||||
|
create table users |
||||
|
( |
||||
|
id INTEGER |
||||
|
primary key autoincrement, |
||||
|
UserName text not null, |
||||
|
Wins int default 0 not null, |
||||
|
Loses int default 0 not null, |
||||
|
IP text not null, |
||||
|
City text not null, |
||||
|
State text not null, |
||||
|
Country text not null, |
||||
|
DateCreated date, |
||||
|
DateUpdated date, |
||||
|
DateDeleted date |
||||
|
); |
||||
|
|
||||
|
create unique index users_UserName |
||||
|
on users (UserName); |
||||
|
|
Binary file not shown.
@ -0,0 +1,55 @@ |
|||||
|
<?php namespace App\Filters; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/Filters/GameFilters.php |
||||
|
* @package App\Filters |
||||
|
* @description |
||||
|
* Runs before start of Program, Calls DB Build if needed. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
use CodeIgniter\HTTP\RequestInterface; |
||||
|
use CodeIgniter\HTTP\ResponseInterface; |
||||
|
use CodeIgniter\Filters\FilterInterface; |
||||
|
|
||||
|
class GameFilters implements FilterInterface |
||||
|
{ |
||||
|
/*************************************************************************************************************** |
||||
|
* @method before |
||||
|
* @description |
||||
|
* Calls setup page if GAME.DB does not exist. |
||||
|
* |
||||
|
* @param RequestInterface $request |
||||
|
* |
||||
|
* @return \CodeIgniter\HTTP\RedirectResponse|mixed |
||||
|
*/ |
||||
|
public function before(RequestInterface $request) |
||||
|
{ |
||||
|
// Database Initalization |
||||
|
if (!file_exists('../app/Database/game.db')) |
||||
|
{ |
||||
|
return redirect()->to(site_url('setup')); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
/*************************************************************************************************************** |
||||
|
* @method after |
||||
|
* @description |
||||
|
* Currently not used. |
||||
|
* |
||||
|
* @param RequestInterface $request |
||||
|
* @param ResponseInterface $response |
||||
|
* |
||||
|
* @return mixed|void |
||||
|
*/ |
||||
|
public function after(RequestInterface $request, ResponseInterface $response) |
||||
|
{ |
||||
|
// Do something here |
||||
|
} |
||||
|
} |
@ -0,0 +1,82 @@ |
|||||
|
<?php namespace App\Libraries; |
||||
|
/******************************************************************************************************************* |
||||
|
* Location Class |
||||
|
* |
||||
|
* @return mixed |
||||
|
* |
||||
|
* @author Rick Hays |
||||
|
* @date 2019-11-16 |
||||
|
* |
||||
|
* @description |
||||
|
* Takes a JSON encoded string from (https://ip-api.io/api/json) |
||||
|
* This site returns several bit of location data from client. |
||||
|
* Class creates Array of data, and using the Class getter to access the data. |
||||
|
* |
||||
|
* NOTE: YOU HAVE TO HAVE A API TO USE THIS CLASS |
||||
|
* The API Key is free for 12,000 queries per month at time of writing. |
||||
|
* |
||||
|
* Place a file in the same location as this Class File and call it |
||||
|
* (location_api_key.php) and in the file place this bit of code: |
||||
|
* |
||||
|
* <?php |
||||
|
* CONST LOCATION_API_KEY = 'Your API Key'; |
||||
|
* |
||||
|
* Get your API at: https://ip-api.io/ |
||||
|
* |
||||
|
* @example |
||||
|
* $Location = new Location(); |
||||
|
* echo $Location->Data['time_zone']; |
||||
|
* echo ($Location->Data['suspiciousFactors']['isSuspicious'] === TRUE) ? 'TRUE' : 'FALSE'; |
||||
|
* |
||||
|
* |
||||
|
* |
||||
|
* -=[ AVAILABLE FIELDS TO CALL ]=- |
||||
|
* 'ip' => string '127.000.000.001' |
||||
|
* 'country_code' => string 'US' |
||||
|
* 'country_name' => string 'United States' |
||||
|
* 'is_in_european_union' => boolean false |
||||
|
* 'region_name' => string 'STATE' |
||||
|
* 'region_code' => string 'ST' |
||||
|
* 'city' => string 'City' |
||||
|
* 'zip_code' => string '00000' |
||||
|
* 'time_zone' => string 'America/Chicago' |
||||
|
* 'latitude' => float 00.0000 |
||||
|
* 'longitude' => float -00.0000 |
||||
|
* 'metro_code' => int 000 |
||||
|
* 'organisation' => string 'Fiber' |
||||
|
* 'flagUrl' => string 'https://ip-api.io/images/flags/us.svg' |
||||
|
* 'emojiFlag' => string '🇺🇸' *** USED ABOVE for SVG NAME *** |
||||
|
* 'currencySymbol' => string '$' |
||||
|
* 'currency' => string 'USD,USN,USS' |
||||
|
* 'callingCode' => string '1' |
||||
|
* 'countryCapital' => string 'Washington D.C.' |
||||
|
* 'suspiciousFactors' => |
||||
|
* 'isProxy' => boolean false |
||||
|
* 'isTorNode' => boolean false |
||||
|
* 'isSpam' => boolean false |
||||
|
* 'isSuspicious' => boolean false |
||||
|
* |
||||
|
******************************************************************************************************************* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XXX Description |
||||
|
* |
||||
|
******************************************************************************************************************/ |
||||
|
require_once 'location_api_key.php'; |
||||
|
|
||||
|
class Location |
||||
|
{ |
||||
|
private $Data; |
||||
|
|
||||
|
public function __construct() |
||||
|
{ |
||||
|
$this->Data = json_decode(file_get_contents('https://ip-api.io/api/json?api_key=LOCATION_API_KEY'), TRUE); |
||||
|
} |
||||
|
|
||||
|
public function __get($item) |
||||
|
{ |
||||
|
if(property_exists($this, $item)) |
||||
|
{ |
||||
|
return $this->$item; |
||||
|
} |
||||
|
} |
||||
|
} |
@ -0,0 +1,34 @@ |
|||||
|
<?php namespace App\Models; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/models/LogModel.php |
||||
|
* @package App\Models |
||||
|
* @description |
||||
|
* Model for the Log Table. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
use CodeIgniter\Model; |
||||
|
|
||||
|
class LogModel extends Model |
||||
|
{ |
||||
|
protected $DBGroup = 'default'; |
||||
|
protected $table = 'Log'; |
||||
|
protected $primaryKey = 'id'; |
||||
|
protected $returnType = 'array'; |
||||
|
protected $allowedFields = ['IP', 'City', 'State', 'Country']; |
||||
|
protected $useTimestamps = TRUE; |
||||
|
protected $createdField = 'DateTime'; |
||||
|
protected $updatedField = ''; |
||||
|
protected $deletedField = ''; |
||||
|
// protected $useSoftDeletes = true; |
||||
|
// protected $validationRules = []; |
||||
|
// protected $validationMessages = []; |
||||
|
// protected $skipValidation = false; |
||||
|
} |
@ -0,0 +1,34 @@ |
|||||
|
<?php namespace App\Models; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/models/PlayModel.php |
||||
|
* @package App\Models |
||||
|
* @description |
||||
|
* Model for the Play Table. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
use CodeIgniter\Model; |
||||
|
|
||||
|
class PlayModel extends Model |
||||
|
{ |
||||
|
protected $DBGroup = 'default'; |
||||
|
protected $table = 'plays'; |
||||
|
protected $primaryKey = 'id'; |
||||
|
protected $returnType = 'array'; |
||||
|
protected $allowedFields = ['UserID', 'UserName', 'IP', 'PlayerPick', 'ComputerPick', 'Result']; |
||||
|
protected $useTimestamps = TRUE; |
||||
|
protected $createdField = 'DateTime'; |
||||
|
protected $updatedField = ''; |
||||
|
protected $deletedField = ''; |
||||
|
// protected $useSoftDeletes = true; |
||||
|
// protected $validationRules = []; |
||||
|
// protected $validationMessages = []; |
||||
|
// protected $skipValidation = false; |
||||
|
} |
@ -0,0 +1,34 @@ |
|||||
|
<?php namespace App\Models; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/models/UserModel.php |
||||
|
* @package App\Models |
||||
|
* @description |
||||
|
* Model for the User Table. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
use CodeIgniter\Model; |
||||
|
|
||||
|
class UserModel extends Model |
||||
|
{ |
||||
|
protected $DBGroup = 'default'; |
||||
|
protected $table = 'users'; |
||||
|
protected $primaryKey = 'id'; |
||||
|
protected $returnType = 'array'; |
||||
|
protected $allowedFields = ['ID', 'UserName', 'Wins', 'Loses', 'Ties', 'IP', 'City', 'State', 'Country', 'CountryCode', 'FlagURL','DateCreated', 'DateUpdated', 'DateDeleted']; |
||||
|
protected $useTimestamps = TRUE; |
||||
|
protected $createdField = 'DateCreated'; |
||||
|
protected $updatedField = 'DateUpdated'; |
||||
|
protected $deletedField = 'DateDeleted'; |
||||
|
// protected $useSoftDeletes = true; |
||||
|
// protected $validationRules = []; |
||||
|
// protected $validationMessages = []; |
||||
|
// protected $skipValidation = false; |
||||
|
} |
@ -0,0 +1,6 @@ |
|||||
|
<?php |
||||
|
use CodeIgniter\CLI\CLI; |
||||
|
|
||||
|
CLI::error('ERROR: ' . $code); |
||||
|
CLI::write($message); |
||||
|
CLI::newLine(); |
@ -0,0 +1,17 @@ |
|||||
|
An uncaught Exception was encountered |
||||
|
|
||||
|
Type: <?= get_class($exception), "\n"; ?> |
||||
|
Message: <?= $message, "\n"; ?> |
||||
|
Filename: <?= $exception->getFile(), "\n"; ?> |
||||
|
Line Number: <?= $exception->getLine(); ?> |
||||
|
|
||||
|
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true): ?> |
||||
|
|
||||
|
Backtrace: |
||||
|
<?php foreach ($exception->getTrace() as $error): ?> |
||||
|
<?php if (isset($error['file'])): ?> |
||||
|
<?= trim('-' . $error['line'] . ' - ' . $error['file'] . '::' . $error['function']) . "\n" ?> |
||||
|
<?php endif ?> |
||||
|
<?php endforeach ?> |
||||
|
|
||||
|
<?php endif ?> |
@ -0,0 +1,5 @@ |
|||||
|
<?php |
||||
|
|
||||
|
// On the CLI, we still want errors in productions |
||||
|
// so just use the exception template. |
||||
|
include __DIR__ . '/error_exception.php'; |
@ -0,0 +1,176 @@ |
|||||
|
body { |
||||
|
height: 100%; |
||||
|
background: #fafafa; |
||||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; |
||||
|
color: #777; |
||||
|
font-weight: 300; |
||||
|
margin: 0; |
||||
|
padding: 0; |
||||
|
} |
||||
|
h1 { |
||||
|
font-weight: lighter; |
||||
|
letter-spacing: 0.8; |
||||
|
font-size: 3rem; |
||||
|
color: #222; |
||||
|
margin: 0; |
||||
|
} |
||||
|
h1.headline { |
||||
|
margin-top: 20%; |
||||
|
font-size: 5rem; |
||||
|
} |
||||
|
.text-center { |
||||
|
text-align: center; |
||||
|
} |
||||
|
p.lead { |
||||
|
font-size: 1.6rem; |
||||
|
} |
||||
|
.container { |
||||
|
max-width: 75rem; |
||||
|
margin: 0 auto; |
||||
|
padding: 1rem; |
||||
|
} |
||||
|
.header { |
||||
|
background: #85271f; |
||||
|
color: #fff; |
||||
|
} |
||||
|
.header h1 { |
||||
|
color: #fff; |
||||
|
} |
||||
|
.header p { |
||||
|
font-size: 1.2rem; |
||||
|
margin: 0; |
||||
|
line-height: 2.5; |
||||
|
} |
||||
|
.header a { |
||||
|
color: rgba(255,255,255,0.5); |
||||
|
margin-left: 2rem; |
||||
|
display: none; |
||||
|
text-decoration: none; |
||||
|
} |
||||
|
.header:hover a { |
||||
|
display: inline; |
||||
|
} |
||||
|
|
||||
|
.footer .container { |
||||
|
border-top: 1px solid #e7e7e7; |
||||
|
margin-top: 1rem; |
||||
|
text-align: center; |
||||
|
} |
||||
|
|
||||
|
.source { |
||||
|
background: #333; |
||||
|
color: #c7c7c7; |
||||
|
padding: 0.5em 1em; |
||||
|
border-radius: 5px; |
||||
|
font-family: Menlo, Monaco, Consolas, "Courier New", monospace; |
||||
|
margin: 0; |
||||
|
} |
||||
|
.source span.line { |
||||
|
line-height: 1.4; |
||||
|
} |
||||
|
.source span.line .number { |
||||
|
color: #666; |
||||
|
} |
||||
|
.source .line .highlight { |
||||
|
display: block; |
||||
|
background: #555; |
||||
|
color: #fff; |
||||
|
} |
||||
|
.source span.highlight .number { |
||||
|
color: #fff; |
||||
|
} |
||||
|
|
||||
|
.tabs { |
||||
|
list-style: none; |
||||
|
list-style-position: inside; |
||||
|
margin: 0; |
||||
|
padding: 0; |
||||
|
margin-bottom: -1px; |
||||
|
} |
||||
|
.tabs li { |
||||
|
display: inline; |
||||
|
} |
||||
|
.tabs a:link, |
||||
|
.tabs a:visited { |
||||
|
padding: 0rem 1rem; |
||||
|
line-height: 2.7; |
||||
|
text-decoration: none; |
||||
|
color: #a7a7a7; |
||||
|
background: #f1f1f1; |
||||
|
border: 1px solid #e7e7e7; |
||||
|
border-bottom: 0; |
||||
|
border-top-left-radius: 5px; |
||||
|
border-top-right-radius: 5px; |
||||
|
display: inline-block; |
||||
|
} |
||||
|
.tabs a:hover { |
||||
|
background: #e7e7e7; |
||||
|
border-color: #e1e1e1; |
||||
|
} |
||||
|
.tabs a.active { |
||||
|
background: #fff; |
||||
|
} |
||||
|
.tab-content { |
||||
|
background: #fff; |
||||
|
border: 1px solid #efefef; |
||||
|
} |
||||
|
.content { |
||||
|
padding: 1rem; |
||||
|
} |
||||
|
.hide { |
||||
|
display: none; |
||||
|
} |
||||
|
|
||||
|
.alert { |
||||
|
margin-top: 2rem; |
||||
|
display: block; |
||||
|
text-align: center; |
||||
|
line-height: 3.0; |
||||
|
background: #d9edf7; |
||||
|
border: 1px solid #bcdff1; |
||||
|
border-radius: 5px; |
||||
|
color: #31708f; |
||||
|
} |
||||
|
ul, ol { |
||||
|
line-height: 1.8; |
||||
|
} |
||||
|
|
||||
|
table { |
||||
|
width: 100%; |
||||
|
overflow: hidden; |
||||
|
} |
||||
|
th { |
||||
|
text-align: left; |
||||
|
border-bottom: 1px solid #e7e7e7; |
||||
|
padding-bottom: 0.5rem; |
||||
|
} |
||||
|
td { |
||||
|
padding: 0.2rem 0.5rem 0.2rem 0; |
||||
|
} |
||||
|
tr:hover td { |
||||
|
background: #f1f1f1; |
||||
|
} |
||||
|
td pre { |
||||
|
white-space: pre-wrap; |
||||
|
} |
||||
|
|
||||
|
.trace a { |
||||
|
color: inherit; |
||||
|
} |
||||
|
.trace table { |
||||
|
width: auto; |
||||
|
} |
||||
|
.trace tr td:first-child { |
||||
|
min-width: 5em; |
||||
|
font-weight: bold; |
||||
|
} |
||||
|
.trace td { |
||||
|
background: #e7e7e7; |
||||
|
padding: 0 1rem; |
||||
|
} |
||||
|
.trace td pre { |
||||
|
margin: 0; |
||||
|
} |
||||
|
.args { |
||||
|
display: none; |
||||
|
} |
@ -0,0 +1,127 @@ |
|||||
|
//--------------------------------------------------------------------
|
||||
|
// Tabs
|
||||
|
//--------------------------------------------------------------------
|
||||
|
|
||||
|
var tabLinks = new Array(); |
||||
|
var contentDivs = new Array(); |
||||
|
|
||||
|
function init () |
||||
|
{ |
||||
|
|
||||
|
// Grab the tab links and content divs from the page
|
||||
|
var tabListItems = document.getElementById('tabs').childNodes; |
||||
|
console.log(tabListItems); |
||||
|
for (var i = 0; i < tabListItems.length; i ++) |
||||
|
{ |
||||
|
if (tabListItems[i].nodeName == "LI") |
||||
|
{ |
||||
|
var tabLink = getFirstChildWithTagName(tabListItems[i], 'A'); |
||||
|
var id = getHash(tabLink.getAttribute('href')); |
||||
|
tabLinks[id] = tabLink; |
||||
|
contentDivs[id] = document.getElementById(id); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// Assign onclick events to the tab links, and
|
||||
|
// highlight the first tab
|
||||
|
var i = 0; |
||||
|
|
||||
|
for (var id in tabLinks) |
||||
|
{ |
||||
|
tabLinks[id].onclick = showTab; |
||||
|
tabLinks[id].onfocus = function () { this.blur() }; |
||||
|
if (i == 0) |
||||
|
{ |
||||
|
tabLinks[id].className = 'active'; |
||||
|
} |
||||
|
i ++; |
||||
|
} |
||||
|
|
||||
|
// Hide all content divs except the first
|
||||
|
var i = 0; |
||||
|
|
||||
|
for (var id in contentDivs) |
||||
|
{ |
||||
|
if (i != 0) |
||||
|
{ |
||||
|
console.log(contentDivs[id]); |
||||
|
contentDivs[id].className = 'content hide'; |
||||
|
} |
||||
|
i ++; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
//--------------------------------------------------------------------
|
||||
|
|
||||
|
function showTab () |
||||
|
{ |
||||
|
var selectedId = getHash(this.getAttribute('href')); |
||||
|
|
||||
|
// Highlight the selected tab, and dim all others.
|
||||
|
// Also show the selected content div, and hide all others.
|
||||
|
for (var id in contentDivs) |
||||
|
{ |
||||
|
if (id == selectedId) |
||||
|
{ |
||||
|
tabLinks[id].className = 'active'; |
||||
|
contentDivs[id].className = 'content'; |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
tabLinks[id].className = ''; |
||||
|
contentDivs[id].className = 'content hide'; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// Stop the browser following the link
|
||||
|
return false; |
||||
|
} |
||||
|
|
||||
|
//--------------------------------------------------------------------
|
||||
|
|
||||
|
function getFirstChildWithTagName (element, tagName) |
||||
|
{ |
||||
|
for (var i = 0; i < element.childNodes.length; i ++) |
||||
|
{ |
||||
|
if (element.childNodes[i].nodeName == tagName) |
||||
|
{ |
||||
|
return element.childNodes[i]; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
//--------------------------------------------------------------------
|
||||
|
|
||||
|
function getHash (url) |
||||
|
{ |
||||
|
var hashPos = url.lastIndexOf('#'); |
||||
|
return url.substring(hashPos + 1); |
||||
|
} |
||||
|
|
||||
|
//--------------------------------------------------------------------
|
||||
|
|
||||
|
function toggle (elem) |
||||
|
{ |
||||
|
elem = document.getElementById(elem); |
||||
|
|
||||
|
if (elem.style && elem.style['display']) |
||||
|
{ |
||||
|
// Only works with the "style" attr
|
||||
|
var disp = elem.style['display']; |
||||
|
} |
||||
|
else if (elem.currentStyle) |
||||
|
{ |
||||
|
// For MSIE, naturally
|
||||
|
var disp = elem.currentStyle['display']; |
||||
|
} |
||||
|
else if (window.getComputedStyle) |
||||
|
{ |
||||
|
// For most other browsers
|
||||
|
var disp = document.defaultView.getComputedStyle(elem, null).getPropertyValue('display'); |
||||
|
} |
||||
|
|
||||
|
// Toggle the state of the "display" style
|
||||
|
elem.style.display = disp == 'block' ? 'none' : 'block'; |
||||
|
|
||||
|
return false; |
||||
|
} |
@ -0,0 +1,84 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html lang="en"> |
||||
|
<head> |
||||
|
<meta charset="utf-8"> |
||||
|
<title>404 Page Not Found</title> |
||||
|
|
||||
|
<style> |
||||
|
div.logo { |
||||
|
height: 200px; |
||||
|
width: 155px; |
||||
|
display: inline-block; |
||||
|
opacity: 0.08; |
||||
|
position: absolute; |
||||
|
top: 2rem; |
||||
|
left: 50%; |
||||
|
margin-left: -73px; |
||||
|
} |
||||
|
body { |
||||
|
height: 100%; |
||||
|
background: #fafafa; |
||||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; |
||||
|
color: #777; |
||||
|
font-weight: 300; |
||||
|
} |
||||
|
h1 { |
||||
|
font-weight: lighter; |
||||
|
letter-spacing: 0.8; |
||||
|
font-size: 3rem; |
||||
|
margin-top: 0; |
||||
|
margin-bottom: 0; |
||||
|
color: #222; |
||||
|
} |
||||
|
.wrap { |
||||
|
max-width: 1024px; |
||||
|
margin: 5rem auto; |
||||
|
padding: 2rem; |
||||
|
background: #fff; |
||||
|
text-align: center; |
||||
|
border: 1px solid #efefef; |
||||
|
border-radius: 0.5rem; |
||||
|
position: relative; |
||||
|
} |
||||
|
pre { |
||||
|
white-space: normal; |
||||
|
margin-top: 1.5rem; |
||||
|
} |
||||
|
code { |
||||
|
background: #fafafa; |
||||
|
border: 1px solid #efefef; |
||||
|
padding: 0.5rem 1rem; |
||||
|
border-radius: 5px; |
||||
|
display: block; |
||||
|
} |
||||
|
p { |
||||
|
margin-top: 1.5rem; |
||||
|
} |
||||
|
.footer { |
||||
|
margin-top: 2rem; |
||||
|
border-top: 1px solid #efefef; |
||||
|
padding: 1em 2em 0 2em; |
||||
|
font-size: 85%; |
||||
|
color: #999; |
||||
|
} |
||||
|
a:active, |
||||
|
a:link, |
||||
|
a:visited { |
||||
|
color: #dd4814; |
||||
|
} |
||||
|
</style> |
||||
|
</head> |
||||
|
<body> |
||||
|
<div class="wrap"> |
||||
|
<h1>404 - File Not Found</h1> |
||||
|
|
||||
|
<p> |
||||
|
<?php if (! empty($message) && $message !== '(null)') : ?> |
||||
|
<?= esc($message) ?> |
||||
|
<?php else : ?> |
||||
|
Sorry! Cannot seem to find the page you were looking for. |
||||
|
<?php endif ?> |
||||
|
</p> |
||||
|
</div> |
||||
|
</body> |
||||
|
</html> |
@ -0,0 +1,401 @@ |
|||||
|
<?php $error_id = uniqid('error', true); ?> |
||||
|
<!doctype html> |
||||
|
<html> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="robots" content="noindex"> |
||||
|
|
||||
|
<title><?= htmlspecialchars($title, ENT_SUBSTITUTE, 'UTF-8') ?></title> |
||||
|
<style type="text/css"> |
||||
|
<?= preg_replace('#[\r\n\t ]+#', ' ', file_get_contents(__DIR__ . DIRECTORY_SEPARATOR . 'debug.css')) ?> |
||||
|
</style> |
||||
|
|
||||
|
<script type="text/javascript"> |
||||
|
<?= file_get_contents(__DIR__ . DIRECTORY_SEPARATOR . 'debug.js') ?> |
||||
|
</script> |
||||
|
</head> |
||||
|
<body onload="init()"> |
||||
|
|
||||
|
<!-- Header --> |
||||
|
<div class="header"> |
||||
|
<div class="container"> |
||||
|
<h1><?= htmlspecialchars($title, ENT_SUBSTITUTE, 'UTF-8'), ($exception->getCode() ? ' #' . $exception->getCode() : '') ?></h1> |
||||
|
<p> |
||||
|
<?= $exception->getMessage() ?> |
||||
|
<a href="https://www.google.com/search?q=<?= urlencode($title . ' ' . preg_replace('#\'.*\'|".*"#Us', '', $exception->getMessage())) ?>" |
||||
|
rel="noreferrer" target="_blank">search →</a> |
||||
|
</p> |
||||
|
</div> |
||||
|
</div> |
||||
|
|
||||
|
<!-- Source --> |
||||
|
<div class="container"> |
||||
|
<p><b><?= static::cleanPath($file, $line) ?></b> at line <b><?= $line ?></b></p> |
||||
|
|
||||
|
<?php if (is_file($file)) : ?> |
||||
|
<div class="source"> |
||||
|
<?= static::highlightFile($file, $line, 15); ?> |
||||
|
</div> |
||||
|
<?php endif; ?> |
||||
|
</div> |
||||
|
|
||||
|
<div class="container"> |
||||
|
|
||||
|
<ul class="tabs" id="tabs"> |
||||
|
<li><a href="#backtrace">Backtrace</a></li> |
||||
|
<li><a href="#server">Server</a></li> |
||||
|
<li><a href="#request">Request</a></li> |
||||
|
<li><a href="#response">Response</a></li> |
||||
|
<li><a href="#files">Files</a></li> |
||||
|
<li><a href="#memory">Memory</a></li> |
||||
|
</li> |
||||
|
</ul> |
||||
|
|
||||
|
<div class="tab-content"> |
||||
|
|
||||
|
<!-- Backtrace --> |
||||
|
<div class="content" id="backtrace"> |
||||
|
|
||||
|
<ol class="trace"> |
||||
|
<?php foreach ($trace as $index => $row) : ?> |
||||
|
|
||||
|
<li> |
||||
|
<p> |
||||
|
<!-- Trace info --> |
||||
|
<?php if (isset($row['file']) && is_file($row['file'])) :?> |
||||
|
<?php |
||||
|
if (isset($row['function']) && in_array($row['function'], ['include', 'include_once', 'require', 'require_once'])) |
||||
|
{ |
||||
|
echo $row['function'] . ' ' . static::cleanPath($row['file']); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
echo static::cleanPath($row['file']) . ' : ' . $row['line']; |
||||
|
} |
||||
|
?> |
||||
|
<?php else : ?> |
||||
|
{PHP internal code} |
||||
|
<?php endif; ?> |
||||
|
|
||||
|
<!-- Class/Method --> |
||||
|
<?php if (isset($row['class'])) : ?> |
||||
|
— <?= $row['class'] . $row['type'] . $row['function'] ?> |
||||
|
<?php if (! empty($row['args'])) : ?> |
||||
|
<?php $args_id = $error_id . 'args' . $index ?> |
||||
|
( <a href="#" onclick="return toggle('<?= $args_id ?>');">arguments</a> ) |
||||
|
<div class="args" id="<?= $args_id ?>"> |
||||
|
<table cellspacing="0"> |
||||
|
|
||||
|
<?php |
||||
|
$params = null; |
||||
|
// Reflection by name is not available for closure function |
||||
|
if (substr( $row['function'], -1 ) !== '}') |
||||
|
{ |
||||
|
$mirror = isset( $row['class'] ) ? new \ReflectionMethod( $row['class'], $row['function'] ) : new \ReflectionFunction( $row['function'] ); |
||||
|
$params = $mirror->getParameters(); |
||||
|
} |
||||
|
foreach ($row['args'] as $key => $value) : ?> |
||||
|
<tr> |
||||
|
<td><code><?= htmlspecialchars(isset($params[$key]) ? '$' . $params[$key]->name : "#$key", ENT_SUBSTITUTE, 'UTF-8') ?></code></td> |
||||
|
<td><pre><?= print_r($value, true) ?></pre></td> |
||||
|
</tr> |
||||
|
<?php endforeach ?> |
||||
|
|
||||
|
</table> |
||||
|
</div> |
||||
|
<?php else : ?> |
||||
|
() |
||||
|
<?php endif; ?> |
||||
|
<?php endif; ?> |
||||
|
|
||||
|
<?php if (! isset($row['class']) && isset($row['function'])) : ?> |
||||
|
— <?= $row['function'] ?>() |
||||
|
<?php endif; ?> |
||||
|
</p> |
||||
|
|
||||
|
<!-- Source? --> |
||||
|
<?php if (isset($row['file']) && is_file($row['file']) && isset($row['class'])) : ?> |
||||
|
<div class="source"> |
||||
|
<?= static::highlightFile($row['file'], $row['line']) ?> |
||||
|
</div> |
||||
|
<?php endif; ?> |
||||
|
</li> |
||||
|
|
||||
|
<?php endforeach; ?> |
||||
|
</ol> |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
<!-- Server --> |
||||
|
<div class="content" id="server"> |
||||
|
<?php foreach (['_SERVER', '_SESSION'] as $var) : ?> |
||||
|
<?php if (empty($GLOBALS[$var]) || ! is_array($GLOBALS[$var])) |
||||
|
{ |
||||
|
continue; |
||||
|
} ?> |
||||
|
|
||||
|
<h3>$<?= $var ?></h3> |
||||
|
|
||||
|
<table> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th>Key</th> |
||||
|
<th>Value</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($GLOBALS[$var] as $key => $value) : ?> |
||||
|
<tr> |
||||
|
<td><?= htmlspecialchars($key, ENT_IGNORE, 'UTF-8') ?></td> |
||||
|
<td> |
||||
|
<?php if (is_string($value)) : ?> |
||||
|
<?= htmlspecialchars($value, ENT_SUBSTITUTE, 'UTF-8') ?> |
||||
|
<?php else: ?> |
||||
|
<?= '<pre>' . print_r($value, true) ?> |
||||
|
<?php endif; ?> |
||||
|
</td> |
||||
|
</tr> |
||||
|
<?php endforeach; ?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
<?php endforeach ?> |
||||
|
|
||||
|
<!-- Constants --> |
||||
|
<?php $constants = get_defined_constants(true); ?> |
||||
|
<?php if (! empty($constants['user'])) : ?> |
||||
|
<h3>Constants</h3> |
||||
|
|
||||
|
<table> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th>Key</th> |
||||
|
<th>Value</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($constants['user'] as $key => $value) : ?> |
||||
|
<tr> |
||||
|
<td><?= htmlspecialchars($key, ENT_IGNORE, 'UTF-8') ?></td> |
||||
|
<td> |
||||
|
<?php if (! is_array($value) && ! is_object($value)) : ?> |
||||
|
<?= htmlspecialchars($value, ENT_SUBSTITUTE, 'UTF-8') ?> |
||||
|
<?php else: ?> |
||||
|
<?= '<pre>' . print_r($value, true) ?> |
||||
|
<?php endif; ?> |
||||
|
</td> |
||||
|
</tr> |
||||
|
<?php endforeach; ?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
<?php endif; ?> |
||||
|
</div> |
||||
|
|
||||
|
<!-- Request --> |
||||
|
<div class="content" id="request"> |
||||
|
<?php $request = \Config\Services::request(); ?> |
||||
|
|
||||
|
<table> |
||||
|
<tbody> |
||||
|
<tr> |
||||
|
<td style="width: 10em">Path</td> |
||||
|
<td><?= $request->uri ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>HTTP Method</td> |
||||
|
<td><?= $request->getMethod(true) ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>IP Address</td> |
||||
|
<td><?= $request->getIPAddress() ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td style="width: 10em">Is AJAX Request?</td> |
||||
|
<td><?= $request->isAJAX() ? 'yes' : 'no' ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>Is CLI Request?</td> |
||||
|
<td><?= $request->isCLI() ? 'yes' : 'no' ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>Is Secure Request?</td> |
||||
|
<td><?= $request->isSecure() ? 'yes' : 'no' ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>User Agent</td> |
||||
|
<td><?= $request->getUserAgent()->getAgentString() ?></td> |
||||
|
</tr> |
||||
|
|
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
|
||||
|
<?php $empty = true; ?> |
||||
|
<?php foreach (['_GET', '_POST', '_COOKIE'] as $var) : ?> |
||||
|
<?php if (empty($GLOBALS[$var]) || ! is_array($GLOBALS[$var])) |
||||
|
{ |
||||
|
continue; |
||||
|
} ?> |
||||
|
|
||||
|
<?php $empty = false; ?> |
||||
|
|
||||
|
<h3>$<?= $var ?></h3> |
||||
|
|
||||
|
<table style="width: 100%"> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th>Key</th> |
||||
|
<th>Value</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($GLOBALS[$var] as $key => $value) : ?> |
||||
|
<tr> |
||||
|
<td><?= htmlspecialchars($key, ENT_IGNORE, 'UTF-8') ?></td> |
||||
|
<td> |
||||
|
<?php if (! is_array($value) && ! is_object($value)) : ?> |
||||
|
<?= htmlspecialchars($value, ENT_SUBSTITUTE, 'UTF-8') ?> |
||||
|
<?php else: ?> |
||||
|
<?= '<pre>' . print_r($value, true) ?> |
||||
|
<?php endif; ?> |
||||
|
</td> |
||||
|
</tr> |
||||
|
<?php endforeach; ?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
<?php endforeach ?> |
||||
|
|
||||
|
<?php if ($empty) : ?> |
||||
|
|
||||
|
<div class="alert"> |
||||
|
No $_GET, $_POST, or $_COOKIE Information to show. |
||||
|
</div> |
||||
|
|
||||
|
<?php endif; ?> |
||||
|
|
||||
|
<?php $headers = $request->getHeaders(); ?> |
||||
|
<?php if (! empty($headers)) : ?> |
||||
|
|
||||
|
<h3>Headers</h3> |
||||
|
|
||||
|
<table> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th>Header</th> |
||||
|
<th>Value</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($headers as $name => $value) : ?> |
||||
|
<?php if (empty($value)) |
||||
|
{ |
||||
|
continue; |
||||
|
} ?> |
||||
|
<?php if (! is_array($value)) |
||||
|
{ |
||||
|
$value = [$value]; |
||||
|
} ?> |
||||
|
<?php foreach ($value as $h) : ?> |
||||
|
<tr> |
||||
|
<td><?= esc($h->getName(), 'html') ?></td> |
||||
|
<td><?= esc($h->getValueLine(), 'html') ?></td> |
||||
|
</tr> |
||||
|
<?php endforeach; ?> |
||||
|
<?php endforeach; ?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
<?php endif; ?> |
||||
|
</div> |
||||
|
|
||||
|
<!-- Response --> |
||||
|
<?php |
||||
|
$response = \Config\Services::response(); |
||||
|
$response->setStatusCode(http_response_code()); |
||||
|
?> |
||||
|
<div class="content" id="response"> |
||||
|
<table> |
||||
|
<tr> |
||||
|
<td style="width: 15em">Response Status</td> |
||||
|
<td><?= $response->getStatusCode() . ' - ' . $response->getReason() ?></td> |
||||
|
</tr> |
||||
|
</table> |
||||
|
|
||||
|
<?php $headers = $response->getHeaders(); ?> |
||||
|
<?php if (! empty($headers)) : ?> |
||||
|
<?php natsort($headers) ?> |
||||
|
|
||||
|
<h3>Headers</h3> |
||||
|
|
||||
|
<table> |
||||
|
<thead> |
||||
|
<tr> |
||||
|
<th>Header</th> |
||||
|
<th>Value</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($headers as $name => $value) : ?> |
||||
|
<tr> |
||||
|
<td><?= esc($name, 'html') ?></td> |
||||
|
<td><?= esc($response->getHeaderLine($name), 'html') ?></td> |
||||
|
</tr> |
||||
|
<?php endforeach; ?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
<?php endif; ?> |
||||
|
</div> |
||||
|
|
||||
|
<!-- Files --> |
||||
|
<div class="content" id="files"> |
||||
|
<?php $files = get_included_files(); ?> |
||||
|
|
||||
|
<ol> |
||||
|
<?php foreach ($files as $file) :?> |
||||
|
<li><?= htmlspecialchars( static::cleanPath($file), ENT_SUBSTITUTE, 'UTF-8') ?></li> |
||||
|
<?php endforeach ?> |
||||
|
</ol> |
||||
|
</div> |
||||
|
|
||||
|
<!-- Memory --> |
||||
|
<div class="content" id="memory"> |
||||
|
|
||||
|
<table> |
||||
|
<tbody> |
||||
|
<tr> |
||||
|
<td>Memory Usage</td> |
||||
|
<td><?= static::describeMemory(memory_get_usage(true)) ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td style="width: 12em">Peak Memory Usage:</td> |
||||
|
<td><?= static::describeMemory(memory_get_peak_usage(true)) ?></td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<td>Memory Limit:</td> |
||||
|
<td><?= ini_get('memory_limit') ?></td> |
||||
|
</tr> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
</div> <!-- /tab-content --> |
||||
|
|
||||
|
</div> <!-- /container --> |
||||
|
|
||||
|
<div class="footer"> |
||||
|
<div class="container"> |
||||
|
|
||||
|
<p> |
||||
|
Displayed at <?= date('H:i:sa') ?> — |
||||
|
PHP: <?= phpversion() ?> — |
||||
|
CodeIgniter: <?= \CodeIgniter\CodeIgniter::CI_VERSION ?> |
||||
|
</p> |
||||
|
|
||||
|
</div> |
||||
|
</div> |
||||
|
|
||||
|
</body> |
||||
|
</html> |
@ -0,0 +1,25 @@ |
|||||
|
<!doctype html> |
||||
|
<html> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="robots" content="noindex"> |
||||
|
|
||||
|
<title>Whoops!</title> |
||||
|
|
||||
|
<style type="text/css"> |
||||
|
<?= preg_replace('#[\r\n\t ]+#', ' ', file_get_contents(__DIR__ . DIRECTORY_SEPARATOR . 'debug.css')) ?> |
||||
|
</style> |
||||
|
</head> |
||||
|
<body> |
||||
|
|
||||
|
<div class="container text-center"> |
||||
|
|
||||
|
<h1 class="headline">Whoops!</h1> |
||||
|
|
||||
|
<p class="lead">We seem to have hit a snag. Please try again later...</p> |
||||
|
|
||||
|
</div> |
||||
|
|
||||
|
</body> |
||||
|
|
||||
|
</html> |
@ -0,0 +1,40 @@ |
|||||
|
<?php namespace App\Views; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/game.php |
||||
|
* @package App\Views |
||||
|
* @description |
||||
|
* View - Opening (Main) Page for program. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<!-- Begin page content --> |
||||
|
<main role="main" class="flex-shrink-0"> |
||||
|
<div class="container"> |
||||
|
<h1 class="mt-5">Rock, Paper, Scissors, Lizard, Spock Game</h1> |
||||
|
<p class="lead">Try your luck at how many times you can beat the computer.</p> |
||||
|
<img src="assets/imgs/rpsls.gif"> |
||||
|
<p>Here are the rules:</p> |
||||
|
<ul> |
||||
|
<li>Rock crushes lizard</li> |
||||
|
<li>Rock crushes scissors</li> |
||||
|
<li>Paper covers rock</li> |
||||
|
<li>Paper disproves Spock</li> |
||||
|
<li>Scissors cuts paper</li> |
||||
|
<li>Scissors decapitates lizard</li> |
||||
|
<li>Lizard poisons Spock</li> |
||||
|
<li>Lizard eats paper</li> |
||||
|
<li>Spock smashes scissors</li> |
||||
|
<li>Spock vaporizes rock</li> |
||||
|
</ul> |
||||
|
<p> </p> |
||||
|
<a href="play" class="btn btn-outline-dark btn-lg" role="button" aria-pressed="true">Play Game!</a> |
||||
|
</div> |
||||
|
</main> |
@ -0,0 +1,38 @@ |
|||||
|
<?php namespace App\Views; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/getUser.php |
||||
|
* @package App\Views |
||||
|
* @description |
||||
|
* View - Form Page to get User Name. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<!-- Begin page content --> |
||||
|
<main role="main" class="flex-shrink-0"> |
||||
|
<div class="container"> |
||||
|
<h1 class="mt-5">Rock, Paper, Scissors, Lizard, Spock Game</h1> |
||||
|
<p class="lead">Try your luck at how many times you can beat the computer.</p> |
||||
|
<p> </p> |
||||
|
<div id="getuser"> |
||||
|
<div class="boxerror bg-warning text-dark"><?=$ErrorCode?></div> |
||||
|
<p> </p> |
||||
|
<p> Before we start playing lets get a user name to keep track of your score and for the Top 10 list.</p> |
||||
|
<form class="mt-2 mt-md-0"> |
||||
|
<input id="UserName" class="form-control mr-sm-2" type="text" value="<?=$UserName?>" placeholder="User Name - only (a-z, A-Z, 0-9, _ - @) are allowed." aria-label="User Name"> |
||||
|
<br> |
||||
|
<button class="btn btn-outline-dark my-2 my-sm-0" type="button" onclick="submitUserName()">Submit</button> |
||||
|
</form> |
||||
|
</div> |
||||
|
</div> |
||||
|
</main> |
||||
|
|
||||
|
|
||||
|
|
@ -0,0 +1,28 @@ |
|||||
|
<?php namespace App\Views\inc; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/inc/footer.php |
||||
|
* @package App\Views\inc |
||||
|
* @description |
||||
|
* View - Footer portion of the Main View Pages. Includes Javascript Loads |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<footer id="footer" class="footer mt-auto py-3"> |
||||
|
<div class="container"> |
||||
|
<span class="text-muted">Copywrite © 2019 - Rick Hays, All Rights Reserved.</span> |
||||
|
<?php echo (ENVIRONMENT === 'development') ? '<br> <span class="text-muted">Page rendered in {elapsed_time} seconds. Environment: ' . ENVIRONMENT . '</span>' : ''; ?> |
||||
|
</div> |
||||
|
</footer> |
||||
|
<script src="assets/js/jquery/jquery-3.4.1.min.js"></script> |
||||
|
<script src="assets/js/bootstrap/bootstrap.bundle.min.js"></script> |
||||
|
<script src="assets/js/game.js"></script> |
||||
|
</body> |
||||
|
</html> |
@ -0,0 +1,31 @@ |
|||||
|
<?php namespace App\Views\inc; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/inc/head.php |
||||
|
* @package App\Views\inc |
||||
|
* @description |
||||
|
* View - Head portion of the Main View Pages. Includes Meta and CSS Loads. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<!DOCTYPE html> |
||||
|
<html lang="en" class="h-100"> |
||||
|
<head> |
||||
|
<meta charset="UTF-8"> |
||||
|
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> |
||||
|
<title>Rock, Paper, Scissors, Lizard, Spock</title> |
||||
|
<meta name="description" |
||||
|
content="Simple game of Rock, Paper, Scissors, Lizard, Spock. Written in HTML and Javascript"> |
||||
|
<meta name="author" content="Rick Hays"> |
||||
|
<link href="assets/css/bootstrap/bootstrap.min.css" rel="stylesheet"> |
||||
|
<link href="assets/css/sticky-footer-navbar.css" rel="stylesheet"> |
||||
|
<link href="assets/css/game.css" rel="stylesheet"> |
||||
|
</head> |
||||
|
<body class="d-flex flex-column h-100"> |
@ -0,0 +1,40 @@ |
|||||
|
<?php namespace App\Views\inc; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/inc/header.php |
||||
|
* @package App\Views\inc |
||||
|
* @description |
||||
|
* View - Header portion of the Main View Pages. Includes Page Header with Nav Bar. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<header> |
||||
|
<!-- Fixed navbar --> |
||||
|
<nav class="navbar navbar-expand-md navbar-dark fixed-top bg-dark"> |
||||
|
<a class="navbar-brand" href="/">R.P.S.L.S Game</a> |
||||
|
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarCollapse" aria-controls="navbarCollapse" aria-expanded="false" aria-label="Toggle navigation"> |
||||
|
<span class="navbar-toggler-icon"></span> |
||||
|
</button> |
||||
|
<div class="collapse navbar-collapse" id="navbarCollapse"> |
||||
|
<ul class="navbar-nav mr-auto"> |
||||
|
<?php echo ($page === '') ? '<li class="nav-item active">' : '<li class="nav-item">'; ?> |
||||
|
<a class="nav-link" href="/">Home <span class="sr-only">(current)</span></a> |
||||
|
</li> |
||||
|
<?php echo ($page === 'play') ? '<li class="nav-item active">' : '<li class="nav-item">'; ?> |
||||
|
<a class="nav-link" href="play">Play Game</a> |
||||
|
</li> |
||||
|
<?php echo ($page === 'top10') ? '<li class="nav-item active">' : '<li class="nav-item">'; ?> |
||||
|
<a class="nav-link" href="top10">Top 10 Scores</a> |
||||
|
</li> |
||||
|
</ul> |
||||
|
</div> |
||||
|
</nav> |
||||
|
</header> |
||||
|
|
@ -0,0 +1,70 @@ |
|||||
|
<?php namespace App\Views; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/play.php |
||||
|
* @package App\Views |
||||
|
* @description |
||||
|
* View - Main game play page, where all the action is. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<!-- Begin page content --> |
||||
|
<main role="main" class="flex-shrink-0"> |
||||
|
<div class="container"> |
||||
|
<h2 class="mt-5">Rock, Paper, Scissors, Lizard, Spock Game</h2> |
||||
|
<p class="lead"><?= $UserName ?>, try your luck at how many times you can beat the computer.</p> |
||||
|
<p> </p> |
||||
|
<div id="game"> |
||||
|
<div class="row"> |
||||
|
<div class="column"><span class="columnspanCountHeader bg-primary text-white">Wins</span></div> |
||||
|
<div class="column"><span class="columnspanCountHeader bg-primary text-white">Loses</span></div> |
||||
|
<div class="column"><span class="columnspanCountHeader bg-primary text-white">Ties</span></div> |
||||
|
</div> |
||||
|
<div class="row"> |
||||
|
<div id="totalWins" class="column"><?= $Wins ?></div> |
||||
|
<div id="totalLoses" class="column"><?= $Loses ?></div> |
||||
|
<div id="totalTies" class="column"><?= $Ties ?></div> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
<button type="button" id="Rock" class="gameButton btn btn-primary btn-lg btn-block">ROCK</button> |
||||
|
<button type="button" id="Paper" class="gameButton btn btn-primary btn-lg btn-block">PAPER</button> |
||||
|
<button type="button" id="Scissors" class="gameButton btn btn-primary btn-lg btn-block">SCISSORS</button> |
||||
|
<button type="button" id="Lizard" class="gameButton btn btn-primary btn-lg btn-block">LIZARD</button> |
||||
|
<button type="button" id="Spock" class="gameButton btn btn-primary btn-lg btn-block">SPOCK</button> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
<div id="RPSLS"> |
||||
|
<span id="textRock" style="display:none;"> <h2>Rock... </h2></span> |
||||
|
<span id="textPaper" style="display:none;"> <h2>Paper... </h2></span> |
||||
|
<span id="textScissors" style="display:none;"> <h2>Scissors... </h2></span> |
||||
|
<span id="textLizard" style="display:none;"> <h2>Lizard... </h2></span> |
||||
|
<span id="textSpock" style="display:none;"> <h2>Spock... </h2></span> |
||||
|
<span id="textComputerHas" style="display:none;"> <h2>... COMPUTER HAS ...</h2></span> |
||||
|
<span id="textComputerPick" style="display:none" class="text-primary"> <h2> </h2></span> |
||||
|
<p> </p> |
||||
|
<span id="textWinLoseTie" style="display:none"> <h2> </h2></span> |
||||
|
<p> </p> |
||||
|
<div class="row"> |
||||
|
<div class="column"> |
||||
|
<span class="columnspanTryAgain"> |
||||
|
<button id="btnTryAgain" type="button" style="display:none;" class="btn btn-primary btn-block">Try Agian.</button> |
||||
|
</span> |
||||
|
</div> |
||||
|
<div class="column"> |
||||
|
<span class="columnspanNoThanks"> |
||||
|
<button id="btnNoThanks" type="button" style="display:none;" class="btn btn-primary btn-block">No Way.</button> |
||||
|
</span> |
||||
|
</div> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
</div> |
||||
|
</div> |
||||
|
</main> |
||||
|
|
@ -0,0 +1,193 @@ |
|||||
|
<?php namespace App\Views; |
||||
|
/****************************************************************************************************************** |
||||
|
* RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
* |
||||
|
* @file app/views/top10.php |
||||
|
* @package App\Views |
||||
|
* @description |
||||
|
* View - Score page for the game. |
||||
|
* @author Rick Hays |
||||
|
* @date 11/15/2019 |
||||
|
* @license MIT |
||||
|
* @copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
* |
||||
|
* Revisions: |
||||
|
* YYYY-MM-DD XX Description |
||||
|
******************************************************************************************************************/ |
||||
|
?> |
||||
|
<!-- Begin page content --> |
||||
|
<main role="main" class="flex-shrink-0"> |
||||
|
<div class="container"> |
||||
|
<h1 class="mt-5">Rock, Paper, Scissors, Lizard, Spock Game</h1> |
||||
|
<h2 class="lead">Top 10 Scores</h2> |
||||
|
<p> </p> |
||||
|
<!-- GAME TOTALS ------------------------------------------------------------------------------------------- --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr> |
||||
|
<th colspan="4" class="text-center bg-primary">Game Totals</th> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<th scope="col"></th> |
||||
|
<th scope="col">Wins</th> |
||||
|
<th scope="col">Loses</th> |
||||
|
<th scope="col">Total</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<tr> |
||||
|
<th scope="row">Player</th> |
||||
|
<td><?= $TotalWinsPlayer->Total ?> </td> |
||||
|
<td><?= $TotalLosesPlayer->Total ?> </td> |
||||
|
<td> </td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<th scope="row">Computer</th> |
||||
|
<td><?= $TotalLosesPlayer->Total ?></td> |
||||
|
<td><?= $TotalWinsPlayer->Total ?></td> |
||||
|
<td> </td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<th scope="row">Ties</th> |
||||
|
<td> </td> |
||||
|
<td> </td> |
||||
|
<td><?= $TotalTiesPlayer->Total ?> </td> |
||||
|
</tr> |
||||
|
<tr> |
||||
|
<th scope="row">Total Plays</th> |
||||
|
<td> </td> |
||||
|
<td> </td> |
||||
|
<td><?= $TotalPlays->Total ?> </td> |
||||
|
</tr> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
|
||||
|
<!-- TOP 10 WINNERS ---------------------------------------------------------------------------------------- --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr><th colspan="3" class="text-center bg-primary">Top 10 Winners</th></tr> |
||||
|
<tr> |
||||
|
<th scope="col">Rank</th> |
||||
|
<th scope="col">User Name</th> |
||||
|
<th scope="col">Points</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($Win10 as $record => $fields):?> |
||||
|
<tr> |
||||
|
<th scope="row"><?= ($record + 1) ?></th> |
||||
|
<?php foreach ($fields as $field => $value):?> |
||||
|
<td><?= $value ?></td> |
||||
|
<?php endforeach;?> |
||||
|
</tr> |
||||
|
<?php endforeach;?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
|
||||
|
<!-- TOP 10 LOSERS ----------------------------------------------------------------------------------------- --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr><th colspan="3" class="text-center bg-primary">Top 10 Losers</th></tr> |
||||
|
<tr> |
||||
|
<th scope="col">Rank</th> |
||||
|
<th scope="col">User Name</th> |
||||
|
<th scope="col">Points</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($Lose10 as $record => $fields):?> |
||||
|
<tr> |
||||
|
<th scope="row"><?= ($record + 1) ?></th> |
||||
|
<?php foreach ($fields as $field => $value):?> |
||||
|
<td><?= $value ?></td> |
||||
|
<?php endforeach;?> |
||||
|
</tr> |
||||
|
<?php endforeach;?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
|
||||
|
<!-- TOP 10 TIES ------------------------------------------------------------------------------------------- --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr><th colspan="3" class="text-center bg-primary">Top 10 Ties</th></tr> |
||||
|
<tr> |
||||
|
<th scope="col">Rank</th> |
||||
|
<th scope="col">User Name</th> |
||||
|
<th scope="col">Points</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($Tie10 as $record => $fields):?> |
||||
|
<tr> |
||||
|
<th scope="row"><?= ($record + 1) ?></th> |
||||
|
<?php foreach ($fields as $field => $value):?> |
||||
|
<td><?= $value ?></td> |
||||
|
<?php endforeach;?> |
||||
|
</tr> |
||||
|
<?php endforeach;?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
|
||||
|
<!-- TOP PLAYER PICKS -------------------------------------------------------------------------------------- --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr><th colspan="3" class="text-center bg-primary">Top Player Picks</th></tr> |
||||
|
<tr> |
||||
|
<th scope="col">Rank</th> |
||||
|
<th scope="col">Pick</th> |
||||
|
<th scope="col">Count</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($PlayerPicks as $record => $fields):?> |
||||
|
<tr> |
||||
|
<th scope="row"><?= ($record + 1) ?></th> |
||||
|
<?php foreach ($fields as $field => $value):?><td><?= $value ?></td><?php endforeach;?> |
||||
|
</tr> |
||||
|
<?php endforeach;?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
|
||||
|
<!-- TOP COMPUTER PICKS ------------------------------------------------------------------------------------ --> |
||||
|
<div class="table-responsive-sm"> |
||||
|
<table class="table table-sm table-striped table-bordered"> |
||||
|
<thead class="thead-dark"> |
||||
|
<tr><th colspan="3" class="text-center bg-primary">Top Computer Picks</th></tr> |
||||
|
<tr> |
||||
|
<th scope="col">Rank</th> |
||||
|
<th scope="col">Pick</th> |
||||
|
<th scope="col">Count</th> |
||||
|
</tr> |
||||
|
</thead> |
||||
|
<tbody> |
||||
|
<?php foreach ($ComputerPicks as $record => $fields):?> |
||||
|
<tr> |
||||
|
<th scope="row"><?= ($record + 1) ?></th> |
||||
|
<?php foreach ($fields as $field => $value):?> |
||||
|
<td><?= $value ?></td> |
||||
|
<?php endforeach;?> |
||||
|
</tr> |
||||
|
<?php endforeach;?> |
||||
|
</tbody> |
||||
|
</table> |
||||
|
</div> |
||||
|
<p> </p> |
||||
|
<a href="play" class="btn btn-outline-dark btn-lg" role="button" aria-pressed="true">Play Game!</a> |
||||
|
<p> </p> |
||||
|
</div> |
||||
|
</main> |
@ -0,0 +1,11 @@ |
|||||
|
<!DOCTYPE html> |
||||
|
<html> |
||||
|
<head> |
||||
|
<title>403 Forbidden</title> |
||||
|
</head> |
||||
|
<body> |
||||
|
|
||||
|
<p>Directory access is forbidden.</p> |
||||
|
|
||||
|
</body> |
||||
|
</html> |
@ -0,0 +1,47 @@ |
|||||
|
# Disable directory browsing |
||||
|
Options All -Indexes |
||||
|
|
||||
|
# ---------------------------------------------------------------------- |
||||
|
# Rewrite engine |
||||
|
# ---------------------------------------------------------------------- |
||||
|
|
||||
|
# Turning on the rewrite engine is necessary for the following rules and features. |
||||
|
# FollowSymLinks must be enabled for this to work. |
||||
|
<IfModule mod_rewrite.c> |
||||
|
Options +FollowSymlinks |
||||
|
RewriteEngine On |
||||
|
|
||||
|
# If you installed CodeIgniter in a subfolder, you will need to |
||||
|
# change the following line to match the subfolder you need. |
||||
|
# http://httpd.apache.org/docs/current/mod/mod_rewrite.html#rewritebase |
||||
|
# RewriteBase / |
||||
|
|
||||
|
# Redirect Trailing Slashes... |
||||
|
RewriteRule ^(.*)/$ /$1 [L,R=301] |
||||
|
|
||||
|
# Rewrite "www.example.com -> example.com" |
||||
|
RewriteCond %{HTTPS} !=on |
||||
|
RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC] |
||||
|
RewriteRule ^ http://%1%{REQUEST_URI} [R=301,L] |
||||
|
|
||||
|
# Checks to see if the user is attempting to access a valid file, |
||||
|
# such as an image or css document, if this isn't true it sends the |
||||
|
# request to the front controller, index.php |
||||
|
RewriteCond %{REQUEST_FILENAME} !-f |
||||
|
RewriteCond %{REQUEST_FILENAME} !-d |
||||
|
RewriteRule ^(.*)$ index.php/$1 [L] |
||||
|
|
||||
|
# Ensure Authorization header is passed along |
||||
|
RewriteCond %{HTTP:Authorization} . |
||||
|
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}] |
||||
|
</IfModule> |
||||
|
|
||||
|
<IfModule !mod_rewrite.c> |
||||
|
# If we don't have mod_rewrite installed, all 404's |
||||
|
# can be sent to index.php, and everything works as normal. |
||||
|
ErrorDocument 404 index.php |
||||
|
</IfModule> |
||||
|
|
||||
|
# Disable server signature start |
||||
|
ServerSignature Off |
||||
|
# Disable server signature end |
File diff suppressed because it is too large
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1,331 @@ |
|||||
|
/*! |
||||
|
* Bootstrap Reboot v4.3.1 (https://getbootstrap.com/) |
||||
|
* Copyright 2011-2019 The Bootstrap Authors |
||||
|
* Copyright 2011-2019 Twitter, Inc. |
||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||||
|
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md) |
||||
|
*/ |
||||
|
*, |
||||
|
*::before, |
||||
|
*::after { |
||||
|
box-sizing: border-box; |
||||
|
} |
||||
|
|
||||
|
html { |
||||
|
font-family: sans-serif; |
||||
|
line-height: 1.15; |
||||
|
-webkit-text-size-adjust: 100%; |
||||
|
-webkit-tap-highlight-color: rgba(0, 0, 0, 0); |
||||
|
} |
||||
|
|
||||
|
article, aside, figcaption, figure, footer, header, hgroup, main, nav, section { |
||||
|
display: block; |
||||
|
} |
||||
|
|
||||
|
body { |
||||
|
margin: 0; |
||||
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; |
||||
|
font-size: 1rem; |
||||
|
font-weight: 400; |
||||
|
line-height: 1.5; |
||||
|
color: #212529; |
||||
|
text-align: left; |
||||
|
background-color: #fff; |
||||
|
} |
||||
|
|
||||
|
[tabindex="-1"]:focus { |
||||
|
outline: 0 !important; |
||||
|
} |
||||
|
|
||||
|
hr { |
||||
|
box-sizing: content-box; |
||||
|
height: 0; |
||||
|
overflow: visible; |
||||
|
} |
||||
|
|
||||
|
h1, h2, h3, h4, h5, h6 { |
||||
|
margin-top: 0; |
||||
|
margin-bottom: 0.5rem; |
||||
|
} |
||||
|
|
||||
|
p { |
||||
|
margin-top: 0; |
||||
|
margin-bottom: 1rem; |
||||
|
} |
||||
|
|
||||
|
abbr[title], |
||||
|
abbr[data-original-title] { |
||||
|
text-decoration: underline; |
||||
|
-webkit-text-decoration: underline dotted; |
||||
|
text-decoration: underline dotted; |
||||
|
cursor: help; |
||||
|
border-bottom: 0; |
||||
|
-webkit-text-decoration-skip-ink: none; |
||||
|
text-decoration-skip-ink: none; |
||||
|
} |
||||
|
|
||||
|
address { |
||||
|
margin-bottom: 1rem; |
||||
|
font-style: normal; |
||||
|
line-height: inherit; |
||||
|
} |
||||
|
|
||||
|
ol, |
||||
|
ul, |
||||
|
dl { |
||||
|
margin-top: 0; |
||||
|
margin-bottom: 1rem; |
||||
|
} |
||||
|
|
||||
|
ol ol, |
||||
|
ul ul, |
||||
|
ol ul, |
||||
|
ul ol { |
||||
|
margin-bottom: 0; |
||||
|
} |
||||
|
|
||||
|
dt { |
||||
|
font-weight: 700; |
||||
|
} |
||||
|
|
||||
|
dd { |
||||
|
margin-bottom: .5rem; |
||||
|
margin-left: 0; |
||||
|
} |
||||
|
|
||||
|
blockquote { |
||||
|
margin: 0 0 1rem; |
||||
|
} |
||||
|
|
||||
|
b, |
||||
|
strong { |
||||
|
font-weight: bolder; |
||||
|
} |
||||
|
|
||||
|
small { |
||||
|
font-size: 80%; |
||||
|
} |
||||
|
|
||||
|
sub, |
||||
|
sup { |
||||
|
position: relative; |
||||
|
font-size: 75%; |
||||
|
line-height: 0; |
||||
|
vertical-align: baseline; |
||||
|
} |
||||
|
|
||||
|
sub { |
||||
|
bottom: -.25em; |
||||
|
} |
||||
|
|
||||
|
sup { |
||||
|
top: -.5em; |
||||
|
} |
||||
|
|
||||
|
a { |
||||
|
color: #007bff; |
||||
|
text-decoration: none; |
||||
|
background-color: transparent; |
||||
|
} |
||||
|
|
||||
|
a:hover { |
||||
|
color: #0056b3; |
||||
|
text-decoration: underline; |
||||
|
} |
||||
|
|
||||
|
a:not([href]):not([tabindex]) { |
||||
|
color: inherit; |
||||
|
text-decoration: none; |
||||
|
} |
||||
|
|
||||
|
a:not([href]):not([tabindex]):hover, a:not([href]):not([tabindex]):focus { |
||||
|
color: inherit; |
||||
|
text-decoration: none; |
||||
|
} |
||||
|
|
||||
|
a:not([href]):not([tabindex]):focus { |
||||
|
outline: 0; |
||||
|
} |
||||
|
|
||||
|
pre, |
||||
|
code, |
||||
|
kbd, |
||||
|
samp { |
||||
|
font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; |
||||
|
font-size: 1em; |
||||
|
} |
||||
|
|
||||
|
pre { |
||||
|
margin-top: 0; |
||||
|
margin-bottom: 1rem; |
||||
|
overflow: auto; |
||||
|
} |
||||
|
|
||||
|
figure { |
||||
|
margin: 0 0 1rem; |
||||
|
} |
||||
|
|
||||
|
img { |
||||
|
vertical-align: middle; |
||||
|
border-style: none; |
||||
|
} |
||||
|
|
||||
|
svg { |
||||
|
overflow: hidden; |
||||
|
vertical-align: middle; |
||||
|
} |
||||
|
|
||||
|
table { |
||||
|
border-collapse: collapse; |
||||
|
} |
||||
|
|
||||
|
caption { |
||||
|
padding-top: 0.75rem; |
||||
|
padding-bottom: 0.75rem; |
||||
|
color: #6c757d; |
||||
|
text-align: left; |
||||
|
caption-side: bottom; |
||||
|
} |
||||
|
|
||||
|
th { |
||||
|
text-align: inherit; |
||||
|
} |
||||
|
|
||||
|
label { |
||||
|
display: inline-block; |
||||
|
margin-bottom: 0.5rem; |
||||
|
} |
||||
|
|
||||
|
button { |
||||
|
border-radius: 0; |
||||
|
} |
||||
|
|
||||
|
button:focus { |
||||
|
outline: 1px dotted; |
||||
|
outline: 5px auto -webkit-focus-ring-color; |
||||
|
} |
||||
|
|
||||
|
input, |
||||
|
button, |
||||
|
select, |
||||
|
optgroup, |
||||
|
textarea { |
||||
|
margin: 0; |
||||
|
font-family: inherit; |
||||
|
font-size: inherit; |
||||
|
line-height: inherit; |
||||
|
} |
||||
|
|
||||
|
button, |
||||
|
input { |
||||
|
overflow: visible; |
||||
|
} |
||||
|
|
||||
|
button, |
||||
|
select { |
||||
|
text-transform: none; |
||||
|
} |
||||
|
|
||||
|
select { |
||||
|
word-wrap: normal; |
||||
|
} |
||||
|
|
||||
|
button, |
||||
|
[type="button"], |
||||
|
[type="reset"], |
||||
|
[type="submit"] { |
||||
|
-webkit-appearance: button; |
||||
|
} |
||||
|
|
||||
|
button:not(:disabled), |
||||
|
[type="button"]:not(:disabled), |
||||
|
[type="reset"]:not(:disabled), |
||||
|
[type="submit"]:not(:disabled) { |
||||
|
cursor: pointer; |
||||
|
} |
||||
|
|
||||
|
button::-moz-focus-inner, |
||||
|
[type="button"]::-moz-focus-inner, |
||||
|
[type="reset"]::-moz-focus-inner, |
||||
|
[type="submit"]::-moz-focus-inner { |
||||
|
padding: 0; |
||||
|
border-style: none; |
||||
|
} |
||||
|
|
||||
|
input[type="radio"], |
||||
|
input[type="checkbox"] { |
||||
|
box-sizing: border-box; |
||||
|
padding: 0; |
||||
|
} |
||||
|
|
||||
|
input[type="date"], |
||||
|
input[type="time"], |
||||
|
input[type="datetime-local"], |
||||
|
input[type="month"] { |
||||
|
-webkit-appearance: listbox; |
||||
|
} |
||||
|
|
||||
|
textarea { |
||||
|
overflow: auto; |
||||
|
resize: vertical; |
||||
|
} |
||||
|
|
||||
|
fieldset { |
||||
|
min-width: 0; |
||||
|
padding: 0; |
||||
|
margin: 0; |
||||
|
border: 0; |
||||
|
} |
||||
|
|
||||
|
legend { |
||||
|
display: block; |
||||
|
width: 100%; |
||||
|
max-width: 100%; |
||||
|
padding: 0; |
||||
|
margin-bottom: .5rem; |
||||
|
font-size: 1.5rem; |
||||
|
line-height: inherit; |
||||
|
color: inherit; |
||||
|
white-space: normal; |
||||
|
} |
||||
|
|
||||
|
progress { |
||||
|
vertical-align: baseline; |
||||
|
} |
||||
|
|
||||
|
[type="number"]::-webkit-inner-spin-button, |
||||
|
[type="number"]::-webkit-outer-spin-button { |
||||
|
height: auto; |
||||
|
} |
||||
|
|
||||
|
[type="search"] { |
||||
|
outline-offset: -2px; |
||||
|
-webkit-appearance: none; |
||||
|
} |
||||
|
|
||||
|
[type="search"]::-webkit-search-decoration { |
||||
|
-webkit-appearance: none; |
||||
|
} |
||||
|
|
||||
|
::-webkit-file-upload-button { |
||||
|
font: inherit; |
||||
|
-webkit-appearance: button; |
||||
|
} |
||||
|
|
||||
|
output { |
||||
|
display: inline-block; |
||||
|
} |
||||
|
|
||||
|
summary { |
||||
|
display: list-item; |
||||
|
cursor: pointer; |
||||
|
} |
||||
|
|
||||
|
template { |
||||
|
display: none; |
||||
|
} |
||||
|
|
||||
|
[hidden] { |
||||
|
display: none !important; |
||||
|
} |
||||
|
/*# sourceMappingURL=bootstrap-reboot.css.map */ |
File diff suppressed because one or more lines are too long
@ -0,0 +1,8 @@ |
|||||
|
/*! |
||||
|
* Bootstrap Reboot v4.3.1 (https://getbootstrap.com/) |
||||
|
* Copyright 2011-2019 The Bootstrap Authors |
||||
|
* Copyright 2011-2019 Twitter, Inc. |
||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE) |
||||
|
* Forked from Normalize.css, licensed MIT (https://github.com/necolas/normalize.css/blob/master/LICENSE.md) |
||||
|
*/*,::after,::before{box-sizing:border-box}html{font-family:sans-serif;line-height:1.15;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-size:1rem;font-weight:400;line-height:1.5;color:#212529;text-align:left;background-color:#fff}[tabindex="-1"]:focus{outline:0!important}hr{box-sizing:content-box;height:0;overflow:visible}h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem}p{margin-top:0;margin-bottom:1rem}abbr[data-original-title],abbr[title]{text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;border-bottom:0;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:#007bff;text-decoration:none;background-color:transparent}a:hover{color:#0056b3;text-decoration:underline}a:not([href]):not([tabindex]){color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus,a:not([href]):not([tabindex]):hover{color:inherit;text-decoration:none}a:not([href]):not([tabindex]):focus{outline:0}code,kbd,pre,samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}pre{margin-top:0;margin-bottom:1rem;overflow:auto}figure{margin:0 0 1rem}img{vertical-align:middle;border-style:none}svg{overflow:hidden;vertical-align:middle}table{border-collapse:collapse}caption{padding-top:.75rem;padding-bottom:.75rem;color:#6c757d;text-align:left;caption-side:bottom}th{text-align:inherit}label{display:inline-block;margin-bottom:.5rem}button{border-radius:0}button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,input{overflow:visible}button,select{text-transform:none}select{word-wrap:normal}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=date],input[type=datetime-local],input[type=month],input[type=time]{-webkit-appearance:listbox}textarea{overflow:auto;resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;max-width:100%;padding:0;margin-bottom:.5rem;font-size:1.5rem;line-height:inherit;color:inherit;white-space:normal}progress{vertical-align:baseline}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{outline-offset:-2px;-webkit-appearance:none}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}output{display:inline-block}summary{display:list-item;cursor:pointer}template{display:none}[hidden]{display:none!important} |
||||
|
/*# sourceMappingURL=bootstrap-reboot.min.css.map */ |
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1,54 @@ |
|||||
|
/* ******************************************************************************************************************** |
||||
|
RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
|
||||
|
File: public/assets/css/game.css |
||||
|
Description: Main CSS Page |
||||
|
Author: Rick Hays |
||||
|
Date: 11/15/2019 |
||||
|
License: MIT |
||||
|
CopyRight: Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
|
||||
|
Revisions: |
||||
|
YYYY-MM-DD XX Description |
||||
|
***************************************************************************************************************** */ |
||||
|
|
||||
|
.column |
||||
|
{ |
||||
|
border-radius: 15px; |
||||
|
float: left; |
||||
|
font-size: 18px; |
||||
|
font-weight: bold; |
||||
|
text-align: center; |
||||
|
width: 33.33%; |
||||
|
} |
||||
|
|
||||
|
.columnspanCountHeader |
||||
|
{ |
||||
|
border-radius: 15px; |
||||
|
display: inline-block; |
||||
|
height: 40px; |
||||
|
line-height: 40px; |
||||
|
margin: 0 auto; |
||||
|
vertical-align: middle; |
||||
|
width: 80% |
||||
|
} |
||||
|
|
||||
|
.columnspanTryAgain, |
||||
|
.columnspanNoThanks |
||||
|
{ |
||||
|
border-radius: 15px; |
||||
|
display: block; |
||||
|
height: 40px; |
||||
|
line-height: 40px; |
||||
|
margin-left: 15px; |
||||
|
vertical-align: middle; |
||||
|
width: 60% |
||||
|
} |
||||
|
|
||||
|
/* Clear floats after the columns */ |
||||
|
.row:after |
||||
|
{ |
||||
|
content: ""; |
||||
|
display: table; |
||||
|
clear: both; |
||||
|
} |
@ -0,0 +1,21 @@ |
|||||
|
/* Custom page CSS -------------------------------------------------- */ |
||||
|
main > .container |
||||
|
{ |
||||
|
padding: 60px 15px 0; |
||||
|
} |
||||
|
|
||||
|
.footer |
||||
|
{ |
||||
|
background-color: #f5f5f5; |
||||
|
} |
||||
|
|
||||
|
.footer > .container |
||||
|
{ |
||||
|
padding-right: 15px; |
||||
|
padding-left: 15px; |
||||
|
} |
||||
|
|
||||
|
code |
||||
|
{ |
||||
|
font-size: 80%; |
||||
|
} |
@ -0,0 +1,21 @@ |
|||||
|
{ |
||||
|
"Users": |
||||
|
[{ |
||||
|
"UserName": "User One", |
||||
|
"Wins": "1", |
||||
|
"Loses": "1", |
||||
|
"LastDate": "2019-11-08", |
||||
|
"IP": "127.0.0.1", |
||||
|
"City": "Dallas", |
||||
|
"Country": "US" |
||||
|
}, |
||||
|
{ |
||||
|
"UserName": "User Two", |
||||
|
"Wins": "2", |
||||
|
"Loses": "2", |
||||
|
"LastDate": "2019-11-08", |
||||
|
"IP": "127.0.0.1", |
||||
|
"City": "Sofia", |
||||
|
"Country": "BG" |
||||
|
}] |
||||
|
} |
After Width: | Height: | Size: 146 KiB |
@ -0,0 +1,131 @@ |
|||||
|
/** |
||||
|
* Game - Main JS file for game play, user, and file save. |
||||
|
* |
||||
|
* @date 2019-11-08 |
||||
|
* @author Rick Hays |
||||
|
* |
||||
|
*/ |
||||
|
|
||||
|
let oUsers = null; |
||||
|
let oCurrentUser = null; |
||||
|
let userID = null; |
||||
|
let userName = ''; |
||||
|
let userWins = 0; |
||||
|
let userLoses = 0; |
||||
|
let userLastPlayed = ''; |
||||
|
let userIP = ''; |
||||
|
let userCity = ''; |
||||
|
let userCountry = ''; |
||||
|
|
||||
|
// Get current JSON file and import into array
|
||||
|
$(document).ready(function () |
||||
|
{ |
||||
|
$.getJSON('data/users.json', function (data) |
||||
|
{ |
||||
|
// Pass data out so it can be used.
|
||||
|
getUsersData(data.Users); |
||||
|
// Start of game screen, determine if there is a cookie or not and display correct screen
|
||||
|
userID = readCookie('userID'); |
||||
|
userID !== null ? $("#game").toggleClass('d-none') : $("#getuser").toggleClass('d-none'); |
||||
|
}, 'json'); |
||||
|
}); |
||||
|
|
||||
|
function getUsersData(data) |
||||
|
{ |
||||
|
oUsers = data; |
||||
|
} |
||||
|
|
||||
|
function writeUserData(data) |
||||
|
{ |
||||
|
|
||||
|
} |
||||
|
|
||||
|
function submitUserName() |
||||
|
{ |
||||
|
UName = $("#UserName").val(); |
||||
|
if (UName === '') |
||||
|
{ |
||||
|
$(".boxerror").html('You must enter a user name to play the game.'); |
||||
|
if ($(".boxerror").hasClass('d-none')) $(".boxerror").toggleClass('d-none'); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
$(".boxerror").toggleClass('d-none'); |
||||
|
userID = checkUserName(oUsers, UName); |
||||
|
// alert('User ID: ' + userID);
|
||||
|
if (userID === null) |
||||
|
{ |
||||
|
createUser(UName); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
// Confirm User before loading else ask for new name
|
||||
|
|
||||
|
// Load user info from userID
|
||||
|
userName = oUsers[userID].UserName; |
||||
|
userWins = oUsers[userID].Wins; |
||||
|
userLoses = oUsers[userID].Loses; |
||||
|
userLastPlayed = oUsers[userID].LastDate; |
||||
|
userIP = oIP.ip; |
||||
|
userCity = oIP.city; |
||||
|
userCountry = oIP.country_code; |
||||
|
|
||||
|
alert('User: ' + userName + ' - City: ' + userCity); |
||||
|
// userIP = GET IP ADDRESS
|
||||
|
// create cookie with userID
|
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function checkUserName(oUsers, name) |
||||
|
{ |
||||
|
for (let i = 0; i < oUsers.length; i++ ) |
||||
|
{ |
||||
|
if (oUsers[i].UserName === name) |
||||
|
return i; |
||||
|
} |
||||
|
return null; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* |
||||
|
* @param UName |
||||
|
* @returns {boolean} |
||||
|
*/ |
||||
|
|
||||
|
function createUser(UName) |
||||
|
{ |
||||
|
userName = UName; |
||||
|
userWins = 0; |
||||
|
userLoses = 0; |
||||
|
userLastPlayed = getCurrentDate(); |
||||
|
userIP = oIP.ip; |
||||
|
userCity = oIP.city; |
||||
|
userCountry = oIP.country_code; |
||||
|
|
||||
|
// Create User Object
|
||||
|
oCurrentUser = |
||||
|
{ |
||||
|
'UserName': userName, |
||||
|
"Wins": userWins, |
||||
|
"Loses": userLoses, |
||||
|
"LastDate": userLastPlayed, |
||||
|
"IP": userIP, |
||||
|
"City": userCity, |
||||
|
"Country": userCountry |
||||
|
}; |
||||
|
// Add to Users Object
|
||||
|
oUsers.push(oCurrentUser); |
||||
|
|
||||
|
// Get ID of JSON User Position
|
||||
|
userID = checkUserName(oUsers, UName); |
||||
|
|
||||
|
// Write JSON file back out.
|
||||
|
|
||||
|
// create cookie with userID
|
||||
|
alert('ID: ' + userID + ' - City: ' + oCurrentUser.City + ' - ' + oUsers[2].City); |
||||
|
} |
||||
|
|
||||
|
function updateUser(UName) |
||||
|
{ |
||||
|
} |
@ -0,0 +1,53 @@ |
|||||
|
/** |
||||
|
* createCookie - Creates a cookie with Name->Value pair, and will stay active for x hours |
||||
|
* |
||||
|
* @date 2019-11-08 |
||||
|
* @author Rick Hays |
||||
|
* @param name |
||||
|
* @param value |
||||
|
* @param hours |
||||
|
*/ |
||||
|
function createCookie(name, value, hours) |
||||
|
{ |
||||
|
let expires = ""; |
||||
|
if (hours) |
||||
|
{ |
||||
|
let date = new Date(); |
||||
|
date.setTime(date.getTime()+(hours*60*60*1000)); |
||||
|
expires='' + date.toUTCString(); //.toGMTString();
|
||||
|
} |
||||
|
document.cookie = name + '=' + value + '; expires=' + expires + "; path=/"; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* readCookie - reads the value of the name->value pair using the name, returns NULL if not found. |
||||
|
* |
||||
|
* @date 2019-11-08 |
||||
|
* @author Rick Hays |
||||
|
* @param name |
||||
|
* @returns {string|null} |
||||
|
*/ |
||||
|
function readCookie(name) |
||||
|
{ |
||||
|
let nameEQ = name + "="; |
||||
|
let ca = document.cookie.split(';'); |
||||
|
for(let i = 0; i < ca.length; i++) |
||||
|
{ |
||||
|
let c = ca[i]; |
||||
|
while (c.charAt(0)==' ') c = c.substring(1, c.length); |
||||
|
if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length, c.length); |
||||
|
} |
||||
|
return null; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* eraseCookie - erases cookie with the name->vaule pair. |
||||
|
* |
||||
|
* @date 2019-11-08 |
||||
|
* @author Rick Hays |
||||
|
* @param name |
||||
|
*/ |
||||
|
function eraseCookie(name) |
||||
|
{ |
||||
|
createCookie(name,"",-1); |
||||
|
} |
@ -0,0 +1,8 @@ |
|||||
|
function getCurrentDate() |
||||
|
{ |
||||
|
let today = new Date(); |
||||
|
let dd = String(today.getDate()).padStart(2, '0'); |
||||
|
let mm = String(today.getMonth() + 1).padStart(2, '0'); //January is 0!
|
||||
|
let yyyy = today.getFullYear(); |
||||
|
return mm + '/' + dd + '/' + yyyy; |
||||
|
} |
@ -0,0 +1,14 @@ |
|||||
|
let oIP = null; |
||||
|
|
||||
|
$(document).ready(function () |
||||
|
{ |
||||
|
$.getJSON("https://ip-api.io/api/json", function(data) |
||||
|
{ |
||||
|
getIPData(data); |
||||
|
}, 'json'); |
||||
|
}); |
||||
|
|
||||
|
function getIPData(data) |
||||
|
{ |
||||
|
oIP = data; |
||||
|
} |
File diff suppressed because it is too large
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -0,0 +1,172 @@ |
|||||
|
/*********************************************************************************************************************** |
||||
|
RPSLS - Rock, Paper, Scissors, Lizard, Spock Game |
||||
|
|
||||
|
@file public/assets/js/game.js |
||||
|
@description Handles all javascript for the game. |
||||
|
@author Rick Hays |
||||
|
@date 11-17-2019 |
||||
|
@license MIT |
||||
|
@copyright Copyright © 2019 - Rick Hays, All Rights Reserved. |
||||
|
|
||||
|
Revisions: |
||||
|
YYYY-MM-DD XX Description |
||||
|
***********************************************************************************************************************/ |
||||
|
|
||||
|
/** |
||||
|
* ALL Processes that require the Document to be ready before running. |
||||
|
*/ |
||||
|
$(document).ready(function () |
||||
|
{ |
||||
|
/** |
||||
|
* Capture the Enter key when in User Name Form |
||||
|
*/ |
||||
|
$("#UserName").keypress(function(e) |
||||
|
{ |
||||
|
if (e.which == 13) |
||||
|
{ |
||||
|
e.preventDefault(); // Stops Enter Key Action
|
||||
|
submitUserName(); |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
/** |
||||
|
* hideElements - Hides the game play elements from view. |
||||
|
*/ |
||||
|
|
||||
|
function hideElements() |
||||
|
{ |
||||
|
$('#textRock, #textPaper, #textScissors, #textLizard, #textSpock, #textComputerHas, #textComputerPick, #textWinLoseTie, #textTryAgain, #btnTryAgain, #btnNoThanks').each(function () |
||||
|
{ |
||||
|
$(this).hide(); |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* TryAgain Button - This is for phone (small) screens, hides game play elements and moves the screen back to the |
||||
|
* top for user to play again. |
||||
|
*/ |
||||
|
$("#btnTryAgain").click(function(evt) |
||||
|
{ |
||||
|
hideElements(); |
||||
|
$('html, body').animate({scrollTop: $(".container").offset().top}); |
||||
|
}); |
||||
|
|
||||
|
/** |
||||
|
* NoThanks Button - Runs endGame from Controller, this removes session and takes you back to home screen. |
||||
|
*/ |
||||
|
$("#btnNoThanks").click(function(evt) |
||||
|
{ |
||||
|
window.location.href = '/endGame'; |
||||
|
}); |
||||
|
|
||||
|
// Game Play Buttons..
|
||||
|
$(".gameButton").click(function(evt) |
||||
|
{ |
||||
|
hideElements(); |
||||
|
|
||||
|
// Get Button Selected
|
||||
|
let gameButton = $(this).attr("id"); |
||||
|
|
||||
|
// AJAX - Play! Pass Option Selected.
|
||||
|
jQuery.ajax( |
||||
|
{ |
||||
|
url: 'play/' + gameButton, |
||||
|
type: 'get', |
||||
|
dataType: "json", |
||||
|
success: function(data) |
||||
|
{ |
||||
|
$('#textComputerPick h2').text(data.ComputerPick); |
||||
|
|
||||
|
$("#textWinLoseTie").removeAttr('class'); |
||||
|
switch(data.Result) |
||||
|
{ |
||||
|
case 'WINNER': |
||||
|
$("#textWinLoseTie").addClass("text-success"); |
||||
|
break; |
||||
|
case 'LOSER': |
||||
|
$("#textWinLoseTie").addClass("text-danger"); |
||||
|
break; |
||||
|
case 'TIE': |
||||
|
$("#textWinLoseTie").addClass("text-info"); |
||||
|
break; |
||||
|
default: |
||||
|
$("#textWinLoseTie").addClass("text-light"); |
||||
|
} |
||||
|
$('#textWinLoseTie h2').text(data.Result + ' - ' + data.ResultText); |
||||
|
$('#textRock, #textPaper, #textScissors, #textLizard, #textSpock, #textComputerHas, #textComputerPick, #textWinLoseTie, #textTryAgain, #btnTryAgain, #btnNoThanks').each(function(fadeInDiv) |
||||
|
{ |
||||
|
$(this).delay(fadeInDiv * 500).fadeIn(1000); |
||||
|
$('html, body').animate({scrollTop:$(document).height()}, '100'); |
||||
|
}); |
||||
|
// Scores
|
||||
|
$('#totalWins').html(data.Wins); |
||||
|
$('#totalLoses').html(data.Loses); |
||||
|
$('#totalTies').html(data.Ties); |
||||
|
}, |
||||
|
error: function(e) |
||||
|
{ |
||||
|
console.log(e.lineNumber + ' - ' + e.script + ': ERROR - ' + e.message); |
||||
|
console.trace(); |
||||
|
} |
||||
|
}); |
||||
|
}); |
||||
|
}); |
||||
|
|
||||
|
/** |
||||
|
* validateUName |
||||
|
* @description |
||||
|
* Simple validation for user name. |
||||
|
* |
||||
|
* @param UName - User Name to validate. |
||||
|
* @returns {boolean} True/False if the name validates to the regex |
||||
|
* |
||||
|
*/ |
||||
|
function validateUName(UName) |
||||
|
{ |
||||
|
var regex = /^([0-9a-zA-Z-_@\.]*)$/; |
||||
|
return (regex.test(UName)) ? true : false; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* submitUserName |
||||
|
* @description |
||||
|
* Handles the form submission. |
||||
|
* |
||||
|
*/ |
||||
|
function submitUserName() |
||||
|
{ |
||||
|
UName = $("#UserName").val(); |
||||
|
if (UName === '') |
||||
|
{ |
||||
|
$(".boxerror").html('You must enter a user name to play the game.'); |
||||
|
} |
||||
|
else if(!validateUName(UName)) |
||||
|
{ |
||||
|
$(".boxerror").html('User Name can only contain characters: (a-z, A-Z, 0-9, - _ @ .) Only. '); |
||||
|
} |
||||
|
else |
||||
|
{ |
||||
|
// AJAX to see if name exists and confirm before
|
||||
|
jQuery.ajax( |
||||
|
{ |
||||
|
url: 'testUser/' + UName, |
||||
|
type: 'get', |
||||
|
async: false, |
||||
|
success: function(data) |
||||
|
{ |
||||
|
if (data !== '0') |
||||
|
{ |
||||
|
let answer = confirm("User Name is already in the Database. \nPress: \nOK - To use this name. \nCANCEL - To pick a new name."); |
||||
|
if (answer == true) |
||||
|
window.location.href = 'createUser/'+UName+'/'+data; |
||||
|
} |
||||
|
else |
||||
|
window.location.href = 'createUser/'+UName+'/'+data; |
||||
|
}, |
||||
|
error: function(e) |
||||
|
{ |
||||
|
alert('84-game.js: ERROR - ' + e.message); |
||||
|
} |
||||
|
}); |
||||
|
} |
||||
|
} |
File diff suppressed because one or more lines are too long
Some files were not shown because too many files changed in this diff
Loading…
Reference in new issue