diff options
author | Malf Furious <m@lfurio.us> | 2017-01-15 20:29:14 -0500 |
---|---|---|
committer | Malf Furious <m@lfurio.us> | 2017-01-15 20:29:14 -0500 |
commit | 92491a36a3f5f02d11b2aa9bf8f3c1418af6e558 (patch) | |
tree | ae11f97d5964af3c8282731f12d325874ad88543 /app/class/mysql.class.php | |
parent | 0d53041fc67e13fc53cca0c993ec1a7a31a5a16e (diff) | |
download | scrott-92491a36a3f5f02d11b2aa9bf8f3c1418af6e558.tar.gz scrott-92491a36a3f5f02d11b2aa9bf8f3c1418af6e558.zip |
Add mysql class
Diffstat (limited to 'app/class/mysql.class.php')
-rw-r--r-- | app/class/mysql.class.php | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/app/class/mysql.class.php b/app/class/mysql.class.php new file mode 100644 index 0000000..fae09bb --- /dev/null +++ b/app/class/mysql.class.php @@ -0,0 +1,68 @@ +<?php + +/* + * SCROTT 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 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. + * + * For more information, please refer to UNLICENSE + */ + +require_once "class/database.class.php"; + +/* + * This class implements support for MySQL and MariaDB via PHP's mysqli + * driver. + */ +class mysql extends database +{ + private $db; + + /* + * Constructor + */ + public function __construct(string $host, string $uname, string $passwd, string $dbname) + { + $this->db = new mysqli($host, $uname, $passwd, $dbname); + + if ($this->db->connect_error) + throw new Exception("Can not connect to MySQL database. Please check your configuration."); + } + + /* + * Close connection to DB + */ + public function close() : void + { + $this->db->close(); + } + + /* + * Make a query of the database. Return data as an array of arrays. + */ + public function query(string $query) : array + { + $arr = array(); + $res = $this->db->query($query); + + if ($res === true || $res === false) + return $arr; + + while (($arr[] = $res->fetch_assoc())); + return $arr; + } + + /* + * Escape a string for use in a query + */ + public function esc(string $str) : string + { + return $this->db->real_escape_string($str); + } +} + +?> |