+ + + + +
+ + + + + diff --git a/src-backup/includes/phpqrcode/CHANGELOG b/src-backup/includes/phpqrcode/CHANGELOG new file mode 100644 index 0000000..1088530 --- /dev/null +++ b/src-backup/includes/phpqrcode/CHANGELOG @@ -0,0 +1,38 @@ +* 1.0.0 build 2010031920 + + - first public release + - help in readme, install + - cleanup ans separation of QRtools and QRspec + - now TCPDF binding requires minimal changes in TCPDF, having most of job + done in QRtools tcpdfBarcodeArray + - nicer QRtools::timeBenchmark output + - license and copyright notices in files + - indent cleanup - from tab to 4spc, keep it that way please :) + - sf project, repository, wiki + - simple code generator in index.php + +* 1.1.0 build 2010032113 + + - added merge tool wich generate merged version of code + located in phpqrcode.php + - splited qrconst.php from qrlib.php + +* 1.1.1 build 2010032405 + + - patch by Rick Seymour allowing saving PNG and displaying it at the same time + - added version info in VERSION file + - modified merge tool to include version info into generated file + - fixed e-mail in almost all head comments + +* 1.1.2 build 2010032722 + + - full integration with TCPDF thanks to Nicola Asuni, it's author + - fixed bug with alphanumeric encoding detection + +* 1.1.3 build 2010081807 + + - short opening tags replaced with standard ones + +* 1.1.4 build 2010100721 + + - added missing static keyword QRinput::check (found by Luke Brookhart, Onjax LLC) diff --git a/src-backup/includes/phpqrcode/INSTALL b/src-backup/includes/phpqrcode/INSTALL new file mode 100644 index 0000000..eac6b07 --- /dev/null +++ b/src-backup/includes/phpqrcode/INSTALL @@ -0,0 +1,67 @@ +== REQUIREMENTS == + + * PHP5 + * PHP GD2 extension with JPEG and PNG support + +== INSTALLATION == + +If you want to recreate cache by yourself make sure cache directory is +writable and you have permisions to write into it. Also make sure you are +able to read files in it if you have cache option enabled + +== CONFIGURATION == + +Feel free to modify config constants in qrconfig.php file. Read about it in +provided comments and project wiki page (links in README file) + +== QUICK START == + +Notice: probably you should'nt use all of this in same script :) + +encode('PHP QR Code :)'); +QRspec::debug($tab, true); + +== TCPDF INTEGRATION == + +Inside bindings/tcpdf you will find slightly modified 2dbarcodes.php. +Instal phpqrcode liblaty inside tcpdf folder, then overwrite (or merge) +2dbarcodes.php + +Then use similar as example #50 from TCPDF examples: + + true, + 'padding' => 4, + 'fgcolor' => array(0,0,0), + 'bgcolor' => false, //array(255,255,255) +); + +//code name: QR, specify error correction level after semicolon (L,M,Q,H) +$pdf->write2DBarcode('PHP QR Code :)', 'QR,L', '', '', 30, 30, $style, 'N'); diff --git a/src-backup/includes/phpqrcode/LICENSE b/src-backup/includes/phpqrcode/LICENSE new file mode 100644 index 0000000..1883303 --- /dev/null +++ b/src-backup/includes/phpqrcode/LICENSE @@ -0,0 +1,165 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + + This version of the GNU Lesser General Public License incorporates +the terms and conditions of version 3 of the GNU General Public +License, supplemented by the additional permissions listed below. + + 0. Additional Definitions. + + As used herein, "this License" refers to version 3 of the GNU Lesser +General Public License, and the "GNU GPL" refers to version 3 of the GNU +General Public License. + + "The Library" refers to a covered work governed by this License, +other than an Application or a Combined Work as defined below. + + An "Application" is any work that makes use of an interface provided +by the Library, but which is not otherwise based on the Library. +Defining a subclass of a class defined by the Library is deemed a mode +of using an interface provided by the Library. + + A "Combined Work" is a work produced by combining or linking an +Application with the Library. The particular version of the Library +with which the Combined Work was made is also called the "Linked +Version". + + The "Minimal Corresponding Source" for a Combined Work means the +Corresponding Source for the Combined Work, excluding any source code +for portions of the Combined Work that, considered in isolation, are +based on the Application, and not on the Linked Version. + + The "Corresponding Application Code" for a Combined Work means the +object code and/or source code for the Application, including any data +and utility programs needed for reproducing the Combined Work from the +Application, but excluding the System Libraries of the Combined Work. + + 1. Exception to Section 3 of the GNU GPL. + + You may convey a covered work under sections 3 and 4 of this License +without being bound by section 3 of the GNU GPL. + + 2. Conveying Modified Versions. + + If you modify a copy of the Library, and, in your modifications, a +facility refers to a function or data to be supplied by an Application +that uses the facility (other than as an argument passed when the +facility is invoked), then you may convey a copy of the modified +version: + + a) under this License, provided that you make a good faith effort to + ensure that, in the event an Application does not supply the + function or data, the facility still operates, and performs + whatever part of its purpose remains meaningful, or + + b) under the GNU GPL, with none of the additional permissions of + this License applicable to that copy. + + 3. Object Code Incorporating Material from Library Header Files. + + The object code form of an Application may incorporate material from +a header file that is part of the Library. You may convey such object +code under terms of your choice, provided that, if the incorporated +material is not limited to numerical parameters, data structure +layouts and accessors, or small macros, inline functions and templates +(ten or fewer lines in length), you do both of the following: + + a) Give prominent notice with each copy of the object code that the + Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the object code with a copy of the GNU GPL and this license + document. + + 4. Combined Works. + + You may convey a Combined Work under terms of your choice that, +taken together, effectively do not restrict modification of the +portions of the Library contained in the Combined Work and reverse +engineering for debugging such modifications, if you also do each of +the following: + + a) Give prominent notice with each copy of the Combined Work that + the Library is used in it and that the Library and its use are + covered by this License. + + b) Accompany the Combined Work with a copy of the GNU GPL and this license + document. + + c) For a Combined Work that displays copyright notices during + execution, include the copyright notice for the Library among + these notices, as well as a reference directing the user to the + copies of the GNU GPL and this license document. + + d) Do one of the following: + + 0) Convey the Minimal Corresponding Source under the terms of this + License, and the Corresponding Application Code in a form + suitable for, and under terms that permit, the user to + recombine or relink the Application with a modified version of + the Linked Version to produce a modified Combined Work, in the + manner specified by section 6 of the GNU GPL for conveying + Corresponding Source. + + 1) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (a) uses at run time + a copy of the Library already present on the user's computer + system, and (b) will operate properly with a modified version + of the Library that is interface-compatible with the Linked + Version. + + e) Provide Installation Information, but only if you would otherwise + be required to provide such information under section 6 of the + GNU GPL, and only to the extent that such information is + necessary to install and execute a modified version of the + Combined Work produced by recombining or relinking the + Application with a modified version of the Linked Version. (If + you use option 4d0, the Installation Information must accompany + the Minimal Corresponding Source and Corresponding Application + Code. If you use option 4d1, you must provide the Installation + Information in the manner specified by section 6 of the GNU GPL + for conveying Corresponding Source.) + + 5. Combined Libraries. + + You may place library facilities that are a work based on the +Library side by side in a single library together with other library +facilities that are not Applications and are not covered by this +License, and convey such a combined library under terms of your +choice, if you do both of the following: + + a) Accompany the combined library with a copy of the same work based + on the Library, uncombined with any other library facilities, + conveyed under the terms of this License. + + b) Give prominent notice with the combined library that part of it + is a work based on the Library, and explaining where to find the + accompanying uncombined form of the same work. + + 6. Revised Versions of the GNU Lesser General Public License. + + The Free Software Foundation may publish revised and/or new versions +of the GNU Lesser General Public License from time to time. Such new +versions will be similar in spirit to the present version, but may +differ in detail to address new problems or concerns. + + Each version is given a distinguishing version number. If the +Library as you received it specifies that a certain numbered version +of the GNU Lesser General Public License "or any later version" +applies to it, you have the option of following the terms and +conditions either of that published version or of any later version +published by the Free Software Foundation. If the Library as you +received it does not specify a version number of the GNU Lesser +General Public License, you may choose any version of the GNU Lesser +General Public License ever published by the Free Software Foundation. + + If the Library as you received it specifies that a proxy can decide +whether future versions of the GNU Lesser General Public License shall +apply, that proxy's public statement of acceptance of any version is +permanent authorization for you to choose that version for the +Library. diff --git a/src-backup/includes/phpqrcode/README b/src-backup/includes/phpqrcode/README new file mode 100644 index 0000000..a022fb5 --- /dev/null +++ b/src-backup/includes/phpqrcode/README @@ -0,0 +1,45 @@ +This is PHP implementation of QR Code 2-D barcode generator. It is pure-php +LGPL-licensed implementation based on C libqrencode by Kentaro Fukuchi. + +== LICENSING == + +Copyright (C) 2010 by Dominik Dzienia + +This library is free software; you can redistribute it and/or modify it under +the terms of the GNU Lesser General Public License as published by the Free +Software Foundation; either version 3 of the License, or any later version. + +This library is distributed in the hope that it will be useful, but WITHOUT ANY +WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A +PARTICULAR PURPOSE. See the GNU Lesser General Public License (LICENSE file) +for more details. + +You should have received a copy of the GNU Lesser General Public License along +with this library; if not, write to the Free Software Foundation, Inc., 51 +Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + +== INSTALATION AND USAGE == + + * INSTALL file + * http://sourceforge.net/apps/mediawiki/phpqrcode/index.php?title=Main_Page + +== CONTACT == + +Fell free to contact me via e-mail (deltalab at poczta dot fm) or using +folowing project pages: + + * http://sourceforge.net/projects/phpqrcode/ + * http://phpqrcode.sourceforge.net/ + +== ACKNOWLEDGMENTS == + +Based on C libqrencode library (ver. 3.1.1) +Copyright (C) 2006-2010 by Kentaro Fukuchi +http://megaui.net/fukuchi/works/qrencode/index.en.html + +QR Code is registered trademarks of DENSO WAVE INCORPORATED in JAPAN and other +countries. + +Reed-Solomon code encoder is written by Phil Karn, KA9Q. +Copyright (C) 2002, 2003, 2004, 2006 Phil Karn, KA9Q + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/VERSION b/src-backup/includes/phpqrcode/VERSION new file mode 100644 index 0000000..9f99279 --- /dev/null +++ b/src-backup/includes/phpqrcode/VERSION @@ -0,0 +1,2 @@ +1.1.4 +2010100721 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/bindings/tcpdf/qrcode.php b/src-backup/includes/phpqrcode/bindings/tcpdf/qrcode.php new file mode 100644 index 0000000..7995460 --- /dev/null +++ b/src-backup/includes/phpqrcode/bindings/tcpdf/qrcode.php @@ -0,0 +1,2875 @@ + +// http://phpqrcode.sourceforge.net/ +// https://sourceforge.net/projects/phpqrcode/ +// +// The "PHP QR Code encoder" is based on +// "C libqrencode library" (ver. 3.1.1) +// License: GNU-LGPL 2.1 +// Copyright (C) 2006-2010 by Kentaro Fukuchi +// http://megaui.net/fukuchi/works/qrencode/index.en.html +// +// Reed-Solomon code encoder is written by Phil Karn, KA9Q. +// Copyright (C) 2002-2006 Phil Karn, KA9Q +// +// QR Code is registered trademark of DENSO WAVE INCORPORATED +// http://www.denso-wave.com/qrcode/index-e.html +// --------------------------------------------------------- +// +// Author: Nicola Asuni +// +// (c) Copyright 2010: +// Nicola Asuni +// Tecnick.com S.r.l. +// Via della Pace, 11 +// 09044 Quartucciu (CA) +// ITALY +// www.tecnick.com +// info@tecnick.com +//============================================================+ + +/** + * Class to create QR-code arrays for TCPDF class. + * QR Code symbol is a 2D barcode that can be scanned by handy terminals such as a mobile phone with CCD. + * The capacity of QR Code is up to 7000 digits or 4000 characters, and has high robustness. + * This class supports QR Code model 2, described in JIS (Japanese Industrial Standards) X0510:2004 or ISO/IEC 18004. + * Currently the following features are not supported: ECI and FNC1 mode, Micro QR Code, QR Code model 1, Structured mode. + * + * This class is derived from "PHP QR Code encoder" by Dominik Dzienia (http://phpqrcode.sourceforge.net/) based on "libqrencode C library 3.1.1." by Kentaro Fukuchi (http://megaui.net/fukuchi/works/qrencode/index.en.html), contains Reed-Solomon code written by Phil Karn, KA9Q. QR Code is registered trademark of DENSO WAVE INCORPORATED (http://www.denso-wave.com/qrcode/index-e.html). + * Please read comments on this class source file for full copyright and license information. + * + * @package com.tecnick.tcpdf + * @abstract Class for generating QR-code array for TCPDF. + * @author Nicola Asuni + * @copyright 2010 Nicola Asuni - Tecnick.com S.r.l (www.tecnick.com) Via Della Pace, 11 - 09044 - Quartucciu (CA) - ITALY - www.tecnick.com - info@tecnick.com + * @link http://www.tcpdf.org + * @license http://www.gnu.org/copyleft/lesser.html LGPL + * @version 1.0.002 + */ + +// definitions +if (!defined('QRCODEDEFS')) { + + /** + * Indicate that definitions for this class are set + */ + define('QRCODEDEFS', true); + + // ----------------------------------------------------- + + // Encoding modes (characters which can be encoded in QRcode) + + /** + * Encoding mode + */ + define('QR_MODE_NL', -1); + + /** + * Encoding mode numeric (0-9). 3 characters are encoded to 10bit length. In theory, 7089 characters or less can be stored in a QRcode. + */ + define('QR_MODE_NM', 0); + + /** + * Encoding mode alphanumeric (0-9A-Z $%*+-./:) 45characters. 2 characters are encoded to 11bit length. In theory, 4296 characters or less can be stored in a QRcode. + */ + define('QR_MODE_AN', 1); + + /** + * Encoding mode 8bit byte data. In theory, 2953 characters or less can be stored in a QRcode. + */ + define('QR_MODE_8B', 2); + + /** + * Encoding mode KANJI. A KANJI character (multibyte character) is encoded to 13bit length. In theory, 1817 characters or less can be stored in a QRcode. + */ + define('QR_MODE_KJ', 3); + + /** + * Encoding mode STRUCTURED (currently unsupported) + */ + define('QR_MODE_ST', 4); + + // ----------------------------------------------------- + + // Levels of error correction. + // QRcode has a function of an error correcting for miss reading that white is black. + // Error correcting is defined in 4 level as below. + + /** + * Error correction level L : About 7% or less errors can be corrected. + */ + define('QR_ECLEVEL_L', 0); + + /** + * Error correction level M : About 15% or less errors can be corrected. + */ + define('QR_ECLEVEL_M', 1); + + /** + * Error correction level Q : About 25% or less errors can be corrected. + */ + define('QR_ECLEVEL_Q', 2); + + /** + * Error correction level H : About 30% or less errors can be corrected. + */ + define('QR_ECLEVEL_H', 3); + + // ----------------------------------------------------- + + // Version. Size of QRcode is defined as version. + // Version is from 1 to 40. + // Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. + // So version 40 is 177*177 matrix. + + /** + * Maximum QR Code version. + */ + define('QRSPEC_VERSION_MAX', 40); + + /** + * Maximum matrix size for maximum version (version 40 is 177*177 matrix). + */ + define('QRSPEC_WIDTH_MAX', 177); + + // ----------------------------------------------------- + + /** + * Matrix index to get width from $capacity array. + */ + define('QRCAP_WIDTH', 0); + + /** + * Matrix index to get number of words from $capacity array. + */ + define('QRCAP_WORDS', 1); + + /** + * Matrix index to get remainder from $capacity array. + */ + define('QRCAP_REMINDER', 2); + + /** + * Matrix index to get error correction level from $capacity array. + */ + define('QRCAP_EC', 3); + + // ----------------------------------------------------- + + // Structure (currently usupported) + + /** + * Number of header bits for structured mode + */ + define('STRUCTURE_HEADER_BITS', 20); + + /** + * Max number of symbols for structured mode + */ + define('MAX_STRUCTURED_SYMBOLS', 16); + + // ----------------------------------------------------- + + // Masks + + /** + * Down point base value for case 1 mask pattern (concatenation of same color in a line or a column) + */ + define('N1', 3); + + /** + * Down point base value for case 2 mask pattern (module block of same color) + */ + define('N2', 3); + + /** + * Down point base value for case 3 mask pattern (1:1:3:1:1(dark:bright:dark:bright:dark)pattern in a line or a column) + */ + define('N3', 40); + + /** + * Down point base value for case 4 mask pattern (ration of dark modules in whole) + */ + define('N4', 10); + + // ----------------------------------------------------- + + // Optimization settings + + /** + * if true, estimates best mask (spec. default, but extremally slow; set to false to significant performance boost but (propably) worst quality code + */ + define('QR_FIND_BEST_MASK', true); + + /** + * if false, checks all masks available, otherwise value tells count of masks need to be checked, mask id are got randomly + */ + define('QR_FIND_FROM_RANDOM', 2); + + /** + * when QR_FIND_BEST_MASK === false + */ + define('QR_DEFAULT_MASK', 2); + + // ----------------------------------------------------- + +} // end of definitions + +// #*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*#*# + +if (!class_exists('QRcode', false)) { + + // for compaibility with PHP4 + if (!function_exists('str_split')) { + /** + * Convert a string to an array (needed for PHP4 compatibility) + * @param string $string The input string. + * @param int $split_length Maximum length of the chunk. + * @return If the optional split_length parameter is specified, the returned array will be broken down into chunks with each being split_length in length, otherwise each chunk will be one character in length. FALSE is returned if split_length is less than 1. If the split_length length exceeds the length of string , the entire string is returned as the first (and only) array element. + */ + function str_split($string, $split_length=1) { + if ((strlen($string) > $split_length) OR (!$split_length)) { + do { + $c = strlen($string); + $parts[] = substr($string, 0, $split_length); + $string = substr($string, $split_length); + } while ($string !== false); + } else { + $parts = array($string); + } + return $parts; + } + } + + // ##################################################### + + /** + * Class to create QR-code arrays for TCPDF class. + * QR Code symbol is a 2D barcode that can be scanned by handy terminals such as a mobile phone with CCD. + * The capacity of QR Code is up to 7000 digits or 4000 characters, and has high robustness. + * This class supports QR Code model 2, described in JIS (Japanese Industrial Standards) X0510:2004 or ISO/IEC 18004. + * Currently the following features are not supported: ECI and FNC1 mode, Micro QR Code, QR Code model 1, Structured mode. + * + * This class is derived from "PHP QR Code encoder" by Dominik Dzienia (http://phpqrcode.sourceforge.net/) based on "libqrencode C library 3.1.1." by Kentaro Fukuchi (http://megaui.net/fukuchi/works/qrencode/index.en.html), contains Reed-Solomon code written by Phil Karn, KA9Q. QR Code is registered trademark of DENSO WAVE INCORPORATED (http://www.denso-wave.com/qrcode/index-e.html). + * Please read comments on this class source file for full copyright and license information. + * + * @name QRcode + * @package com.tecnick.tcpdf + * @abstract Class for generating QR-code array for TCPDF. + * @author Nicola Asuni + * @copyright 2010 Nicola Asuni - Tecnick.com S.r.l (www.tecnick.com) Via Della Pace, 11 - 09044 - Quartucciu (CA) - ITALY - www.tecnick.com - info@tecnick.com + * @link http://www.tcpdf.org + * @license http://www.gnu.org/copyleft/lesser.html LGPL + * @version 1.0.002 + */ + class QRcode { + + /** + * @var barcode array to be returned which is readable by TCPDF + * @access protected + */ + protected $barcode_array = array(); + + /** + * @var QR code version. Size of QRcode is defined as version. Version is from 1 to 40. Version 1 is 21*21 matrix. And 4 modules increases whenever 1 version increases. So version 40 is 177*177 matrix. + * @access protected + */ + protected $version = 0; + + /** + * @var Levels of error correction. See definitions for possible values. + * @access protected + */ + protected $level = QR_ECLEVEL_L; + + /** + * @var Encoding mode + * @access protected + */ + protected $hint = QR_MODE_8B; + + /** + * @var if true the input string will be converted to uppercase + * @access protected + */ + protected $casesensitive = true; + + /** + * @var structured QR code (not supported yet) + * @access protected + */ + protected $structured = 0; + + /** + * @var mask data + * @access protected + */ + protected $data; + + // FrameFiller + + /** + * @var width + * @access protected + */ + protected $width; + + /** + * @var frame + * @access protected + */ + protected $frame; + + /** + * @var X position of bit + * @access protected + */ + protected $x; + + /** + * @var Y position of bit + * @access protected + */ + protected $y; + + /** + * @var direction + * @access protected + */ + protected $dir; + + /** + * @var single bit + * @access protected + */ + protected $bit; + + // ---- QRrawcode ---- + + /** + * @var data code + * @access protected + */ + protected $datacode = array(); + + /** + * @var error correction code + * @access protected + */ + protected $ecccode = array(); + + /** + * @var blocks + * @access protected + */ + protected $blocks; + + /** + * @var Reed-Solomon blocks + * @access protected + */ + protected $rsblocks = array(); //of RSblock + + /** + * @var counter + * @access protected + */ + protected $count; + + /** + * @var data length + * @access protected + */ + protected $dataLength; + + /** + * @var error correction length + * @access protected + */ + protected $eccLength; + + /** + * @var b1 + * @access protected + */ + protected $b1; + + // ---- QRmask ---- + + /** + * @var run length + * @access protected + */ + protected $runLength = array(); + + // ---- QRsplit ---- + + /** + * @var input data string + * @access protected + */ + protected $dataStr = ''; + + /** + * @var input items + * @access protected + */ + protected $items; + + // Reed-Solomon items + + /** + * @var Reed-Solomon items + * @access protected + */ + protected $rsitems = array(); + + /** + * @var array of frames + * @access protected + */ + protected $frames = array(); + + /** + * @var alphabet-numeric convesion table + * @access protected + */ + protected $anTable = array( + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // + 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, // + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, // + -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, // + 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, // + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 // + ); + + /** + * @var array Table of the capacity of symbols + * See Table 1 (pp.13) and Table 12-16 (pp.30-36), JIS X0510:2004. + * @access protected + */ + protected $capacity = array( + array( 0, 0, 0, array( 0, 0, 0, 0)), // + array( 21, 26, 0, array( 7, 10, 13, 17)), // 1 + array( 25, 44, 7, array( 10, 16, 22, 28)), // + array( 29, 70, 7, array( 15, 26, 36, 44)), // + array( 33, 100, 7, array( 20, 36, 52, 64)), // + array( 37, 134, 7, array( 26, 48, 72, 88)), // 5 + array( 41, 172, 7, array( 36, 64, 96, 112)), // + array( 45, 196, 0, array( 40, 72, 108, 130)), // + array( 49, 242, 0, array( 48, 88, 132, 156)), // + array( 53, 292, 0, array( 60, 110, 160, 192)), // + array( 57, 346, 0, array( 72, 130, 192, 224)), // 10 + array( 61, 404, 0, array( 80, 150, 224, 264)), // + array( 65, 466, 0, array( 96, 176, 260, 308)), // + array( 69, 532, 0, array( 104, 198, 288, 352)), // + array( 73, 581, 3, array( 120, 216, 320, 384)), // + array( 77, 655, 3, array( 132, 240, 360, 432)), // 15 + array( 81, 733, 3, array( 144, 280, 408, 480)), // + array( 85, 815, 3, array( 168, 308, 448, 532)), // + array( 89, 901, 3, array( 180, 338, 504, 588)), // + array( 93, 991, 3, array( 196, 364, 546, 650)), // + array( 97, 1085, 3, array( 224, 416, 600, 700)), // 20 + array(101, 1156, 4, array( 224, 442, 644, 750)), // + array(105, 1258, 4, array( 252, 476, 690, 816)), // + array(109, 1364, 4, array( 270, 504, 750, 900)), // + array(113, 1474, 4, array( 300, 560, 810, 960)), // + array(117, 1588, 4, array( 312, 588, 870, 1050)), // 25 + array(121, 1706, 4, array( 336, 644, 952, 1110)), // + array(125, 1828, 4, array( 360, 700, 1020, 1200)), // + array(129, 1921, 3, array( 390, 728, 1050, 1260)), // + array(133, 2051, 3, array( 420, 784, 1140, 1350)), // + array(137, 2185, 3, array( 450, 812, 1200, 1440)), // 30 + array(141, 2323, 3, array( 480, 868, 1290, 1530)), // + array(145, 2465, 3, array( 510, 924, 1350, 1620)), // + array(149, 2611, 3, array( 540, 980, 1440, 1710)), // + array(153, 2761, 3, array( 570, 1036, 1530, 1800)), // + array(157, 2876, 0, array( 570, 1064, 1590, 1890)), // 35 + array(161, 3034, 0, array( 600, 1120, 1680, 1980)), // + array(165, 3196, 0, array( 630, 1204, 1770, 2100)), // + array(169, 3362, 0, array( 660, 1260, 1860, 2220)), // + array(173, 3532, 0, array( 720, 1316, 1950, 2310)), // + array(177, 3706, 0, array( 750, 1372, 2040, 2430)) // 40 + ); + + /** + * @var array Length indicator + * @access protected + */ + protected $lengthTableBits = array( + array(10, 12, 14), + array( 9, 11, 13), + array( 8, 16, 16), + array( 8, 10, 12) + ); + + /** + * @var array Table of the error correction code (Reed-Solomon block) + * See Table 12-16 (pp.30-36), JIS X0510:2004. + * @access protected + */ + protected $eccTable = array( + array(array( 0, 0), array( 0, 0), array( 0, 0), array( 0, 0)), // + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), // 1 + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), // + array(array( 1, 0), array( 1, 0), array( 2, 0), array( 2, 0)), // + array(array( 1, 0), array( 2, 0), array( 2, 0), array( 4, 0)), // + array(array( 1, 0), array( 2, 0), array( 2, 2), array( 2, 2)), // 5 + array(array( 2, 0), array( 4, 0), array( 4, 0), array( 4, 0)), // + array(array( 2, 0), array( 4, 0), array( 2, 4), array( 4, 1)), // + array(array( 2, 0), array( 2, 2), array( 4, 2), array( 4, 2)), // + array(array( 2, 0), array( 3, 2), array( 4, 4), array( 4, 4)), // + array(array( 2, 2), array( 4, 1), array( 6, 2), array( 6, 2)), // 10 + array(array( 4, 0), array( 1, 4), array( 4, 4), array( 3, 8)), // + array(array( 2, 2), array( 6, 2), array( 4, 6), array( 7, 4)), // + array(array( 4, 0), array( 8, 1), array( 8, 4), array(12, 4)), // + array(array( 3, 1), array( 4, 5), array(11, 5), array(11, 5)), // + array(array( 5, 1), array( 5, 5), array( 5, 7), array(11, 7)), // 15 + array(array( 5, 1), array( 7, 3), array(15, 2), array( 3, 13)), // + array(array( 1, 5), array(10, 1), array( 1, 15), array( 2, 17)), // + array(array( 5, 1), array( 9, 4), array(17, 1), array( 2, 19)), // + array(array( 3, 4), array( 3, 11), array(17, 4), array( 9, 16)), // + array(array( 3, 5), array( 3, 13), array(15, 5), array(15, 10)), // 20 + array(array( 4, 4), array(17, 0), array(17, 6), array(19, 6)), // + array(array( 2, 7), array(17, 0), array( 7, 16), array(34, 0)), // + array(array( 4, 5), array( 4, 14), array(11, 14), array(16, 14)), // + array(array( 6, 4), array( 6, 14), array(11, 16), array(30, 2)), // + array(array( 8, 4), array( 8, 13), array( 7, 22), array(22, 13)), // 25 + array(array(10, 2), array(19, 4), array(28, 6), array(33, 4)), // + array(array( 8, 4), array(22, 3), array( 8, 26), array(12, 28)), // + array(array( 3, 10), array( 3, 23), array( 4, 31), array(11, 31)), // + array(array( 7, 7), array(21, 7), array( 1, 37), array(19, 26)), // + array(array( 5, 10), array(19, 10), array(15, 25), array(23, 25)), // 30 + array(array(13, 3), array( 2, 29), array(42, 1), array(23, 28)), // + array(array(17, 0), array(10, 23), array(10, 35), array(19, 35)), // + array(array(17, 1), array(14, 21), array(29, 19), array(11, 46)), // + array(array(13, 6), array(14, 23), array(44, 7), array(59, 1)), // + array(array(12, 7), array(12, 26), array(39, 14), array(22, 41)), // 35 + array(array( 6, 14), array( 6, 34), array(46, 10), array( 2, 64)), // + array(array(17, 4), array(29, 14), array(49, 10), array(24, 46)), // + array(array( 4, 18), array(13, 32), array(48, 14), array(42, 32)), // + array(array(20, 4), array(40, 7), array(43, 22), array(10, 67)), // + array(array(19, 6), array(18, 31), array(34, 34), array(20, 61)) // 40 + ); + + /** + * @var array Positions of alignment patterns. + * This array includes only the second and the third position of the alignment patterns. Rest of them can be calculated from the distance between them. + * See Table 1 in Appendix E (pp.71) of JIS X0510:2004. + * @access protected + */ + protected $alignmentPattern = array( + array( 0, 0), + array( 0, 0), array(18, 0), array(22, 0), array(26, 0), array(30, 0), // 1- 5 + array(34, 0), array(22, 38), array(24, 42), array(26, 46), array(28, 50), // 6-10 + array(30, 54), array(32, 58), array(34, 62), array(26, 46), array(26, 48), // 11-15 + array(26, 50), array(30, 54), array(30, 56), array(30, 58), array(34, 62), // 16-20 + array(28, 50), array(26, 50), array(30, 54), array(28, 54), array(32, 58), // 21-25 + array(30, 58), array(34, 62), array(26, 50), array(30, 54), array(26, 52), // 26-30 + array(30, 56), array(34, 60), array(30, 58), array(34, 62), array(30, 54), // 31-35 + array(24, 50), array(28, 54), array(32, 58), array(26, 54), array(30, 58) // 35-40 + ); + + /** + * @var array Version information pattern (BCH coded). + * See Table 1 in Appendix D (pp.68) of JIS X0510:2004. + * size: [QRSPEC_VERSION_MAX - 6] + * @access protected + */ + protected $versionPattern = array( + 0x07c94, 0x085bc, 0x09a99, 0x0a4d3, 0x0bbf6, 0x0c762, 0x0d847, 0x0e60d, // + 0x0f928, 0x10b78, 0x1145d, 0x12a17, 0x13532, 0x149a6, 0x15683, 0x168c9, // + 0x177ec, 0x18ec4, 0x191e1, 0x1afab, 0x1b08e, 0x1cc1a, 0x1d33f, 0x1ed75, // + 0x1f250, 0x209d5, 0x216f0, 0x228ba, 0x2379f, 0x24b0b, 0x2542e, 0x26a64, // + 0x27541, 0x28c69 + ); + + /** + * @var array Format information + * @access protected + */ + protected $formatInfo = array( + array(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976), // + array(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0), // + array(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed), // + array(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b) // + ); + + + // ------------------------------------------------- + // ------------------------------------------------- + + + /** + * This is the class constructor. + * Creates a QRcode object + * @param string $code code to represent using QRcode + * @param string $eclevel error level:
  • L : About 7% or less errors can be corrected.
  • M : About 15% or less errors can be corrected.
  • Q : About 25% or less errors can be corrected.
  • H : About 30% or less errors can be corrected.
+ * @access public + * @since 1.0.000 + */ + public function __construct($code, $eclevel = 'L') { + $barcode_array = array(); + if ((is_null($code)) OR ($code == '\0') OR ($code == '')) { + return false; + } + // set error correction level + $this->level = array_search($eclevel, array('L', 'M', 'Q', 'H')); + if ($this->level === false) { + $this->level = QR_ECLEVEL_L; + } + if (($this->hint != QR_MODE_8B) AND ($this->hint != QR_MODE_KJ)) { + return false; + } + if (($this->version < 0) OR ($this->version > QRSPEC_VERSION_MAX)) { + return false; + } + $this->items = array(); + $this->encodeString($code); + $qrTab = $this->binarize($this->data); + $size = count($qrTab); + $barcode_array['num_rows'] = $size; + $barcode_array['num_cols'] = $size; + $barcode_array['bcode'] = array(); + foreach ($qrTab as $line) { + $arrAdd = array(); + foreach (str_split($line) as $char) { + $arrAdd[] = ($char=='1')?1:0; + } + $barcode_array['bcode'][] = $arrAdd; + } + $this->barcode_array = $barcode_array; + } + + /** + * Returns a barcode array which is readable by TCPDF + * @return array barcode array readable by TCPDF; + * @access public + */ + public function getBarcodeArray() { + return $this->barcode_array; + } + + /** + * Convert the frame in binary form + * @param array $frame array to binarize + * @return array frame in binary form + */ + protected function binarize($frame) { + $len = count($frame); + // the frame is square (width = height) + foreach ($frame as &$frameLine) { + for ($i=0; $i<$len; $i++) { + $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0'; + } + } + return $frame; + } + + /** + * Encode the input string to QR code + * @param string $string input string to encode + */ + protected function encodeString($string) { + $this->dataStr = $string; + if (!$this->casesensitive) { + $this->toUpper(); + } + $ret = $this->splitString(); + if ($ret < 0) { + return NULL; + } + $this->encodeMask(-1); + } + + /** + * Encode mask + * @param int $mask masking mode + */ + protected function encodeMask($mask) { + $spec = array(0, 0, 0, 0, 0); + $this->datacode = $this->getByteStream($this->items); + if (is_null($this->datacode)) { + return NULL; + } + $spec = $this->getEccSpec($this->version, $this->level, $spec); + $this->b1 = $this->rsBlockNum1($spec); + $this->dataLength = $this->rsDataLength($spec); + $this->eccLength = $this->rsEccLength($spec); + $this->ecccode = array_fill(0, $this->eccLength, 0); + $this->blocks = $this->rsBlockNum($spec); + $ret = $this->init($spec); + if ($ret < 0) { + return NULL; + } + $this->count = 0; + $this->width = $this->getWidth($this->version); + $this->frame = $this->newFrame($this->version); + $this->x = $this->width - 1; + $this->y = $this->width - 1; + $this->dir = -1; + $this->bit = -1; + // inteleaved data and ecc codes + for ($i=0; $i < ($this->dataLength + $this->eccLength); $i++) { + $code = $this->getCode(); + $bit = 0x80; + for ($j=0; $j<8; $j++) { + $addr = $this->getNextPosition(); + $this->setFrameAt($addr, 0x02 | (($bit & $code) != 0)); + $bit = $bit >> 1; + } + } + // remainder bits + $j = $this->getRemainder($this->version); + for ($i=0; $i<$j; $i++) { + $addr = $this->getNextPosition(); + $this->setFrameAt($addr, 0x02); + } + // masking + $this->runLength = array_fill(0, QRSPEC_WIDTH_MAX + 1, 0); + if ($mask < 0) { + if (QR_FIND_BEST_MASK) { + $masked = $this->mask($this->width, $this->frame, $this->level); + } else { + $masked = $this->makeMask($this->width, $this->frame, (intval(QR_DEFAULT_MASK) % 8), $this->level); + } + } else { + $masked = $this->makeMask($this->width, $this->frame, $mask, $this->level); + } + if ($masked == NULL) { + return NULL; + } + $this->data = $masked; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // FrameFiller + + /** + * Set frame value at specified position + * @param array $at x,y position + * @param int $val value of the character to set + */ + protected function setFrameAt($at, $val) { + $this->frame[$at['y']][$at['x']] = chr($val); + } + + /** + * Get frame value at specified position + * @param array $at x,y position + * @return value at specified position + */ + protected function getFrameAt($at) { + return ord($this->frame[$at['y']][$at['x']]); + } + + /** + * Return the next frame position + * @return array of x,y coordinates + */ + protected function getNextPosition() { + do { + if ($this->bit == -1) { + $this->bit = 0; + return array('x'=>$this->x, 'y'=>$this->y); + } + $x = $this->x; + $y = $this->y; + $w = $this->width; + if ($this->bit == 0) { + $x--; + $this->bit++; + } else { + $x++; + $y += $this->dir; + $this->bit--; + } + if ($this->dir < 0) { + if ($y < 0) { + $y = 0; + $x -= 2; + $this->dir = 1; + if ($x == 6) { + $x--; + $y = 9; + } + } + } else { + if ($y == $w) { + $y = $w - 1; + $x -= 2; + $this->dir = -1; + if ($x == 6) { + $x--; + $y -= 8; + } + } + } + if (($x < 0) OR ($y < 0)) { + return NULL; + } + $this->x = $x; + $this->y = $y; + } while(ord($this->frame[$y][$x]) & 0x80); + return array('x'=>$x, 'y'=>$y); + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRrawcode + + /** + * Initialize code. + * @param array $spec array of ECC specification + * @return 0 in case of success, -1 in case of error + */ + protected function init($spec) { + $dl = $this->rsDataCodes1($spec); + $el = $this->rsEccCodes1($spec); + $rs = $this->init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + $blockNo = 0; + $dataPos = 0; + $eccPos = 0; + $endfor = $this->rsBlockNum1($spec); + for ($i=0; $i < $endfor; ++$i) { + $ecc = array_slice($this->ecccode, $eccPos); + $this->rsblocks[$blockNo] = array(); + $this->rsblocks[$blockNo]['dataLength'] = $dl; + $this->rsblocks[$blockNo]['data'] = array_slice($this->datacode, $dataPos); + $this->rsblocks[$blockNo]['eccLength'] = $el; + $ecc = $this->encode_rs_char($rs, $this->rsblocks[$blockNo]['data'], $ecc); + $this->rsblocks[$blockNo]['ecc'] = $ecc; + $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + if ($this->rsBlockNum2($spec) == 0) { + return 0; + } + $dl = $this->rsDataCodes2($spec); + $el = $this->rsEccCodes2($spec); + $rs = $this->init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + if ($rs == NULL) { + return -1; + } + $endfor = $this->rsBlockNum2($spec); + for ($i=0; $i < $endfor; ++$i) { + $ecc = array_slice($this->ecccode, $eccPos); + $this->rsblocks[$blockNo] = array(); + $this->rsblocks[$blockNo]['dataLength'] = $dl; + $this->rsblocks[$blockNo]['data'] = array_slice($this->datacode, $dataPos); + $this->rsblocks[$blockNo]['eccLength'] = $el; + $ecc = $this->encode_rs_char($rs, $this->rsblocks[$blockNo]['data'], $ecc); + $this->rsblocks[$blockNo]['ecc'] = $ecc; + $this->ecccode = array_merge(array_slice($this->ecccode, 0, $eccPos), $ecc); + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + return 0; + } + + /** + * Return Reed-Solomon block code. + * @return array rsblocks + */ + protected function getCode() { + if ($this->count < $this->dataLength) { + $row = $this->count % $this->blocks; + $col = $this->count / $this->blocks; + if ($col >= $this->rsblocks[0]['dataLength']) { + $row += $this->b1; + } + $ret = $this->rsblocks[$row]['data'][$col]; + } elseif ($this->count < $this->dataLength + $this->eccLength) { + $row = ($this->count - $this->dataLength) % $this->blocks; + $col = ($this->count - $this->dataLength) / $this->blocks; + $ret = $this->rsblocks[$row]['ecc'][$col]; + } else { + return 0; + } + $this->count++; + return $ret; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRmask + + /** + * Write Format Information on frame and returns the number of black bits + * @param int $width frame width + * @param array $frame frame + * @param array $mask masking mode + * @param int $level error correction level + * @return int blacks + */ + protected function writeFormatInformation($width, &$frame, $mask, $level) { + $blacks = 0; + $format = $this->getFormatInfo($mask, $level); + for ($i=0; $i<8; ++$i) { + if ($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + $frame[8][$width - 1 - $i] = chr($v); + if ($i < 6) { + $frame[$i][8] = chr($v); + } else { + $frame[$i + 1][8] = chr($v); + } + $format = $format >> 1; + } + for ($i=0; $i<7; ++$i) { + if ($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + $frame[$width - 7 + $i][8] = chr($v); + if ($i == 0) { + $frame[8][7] = chr($v); + } else { + $frame[8][6 - $i] = chr($v); + } + $format = $format >> 1; + } + return $blacks; + } + + /** + * mask0 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask0($x, $y) { + return ($x + $y) & 1; + } + + /** + * mask1 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask1($x, $y) { + return ($y & 1); + } + + /** + * mask2 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask2($x, $y) { + return ($x % 3); + } + + /** + * mask3 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask3($x, $y) { + return ($x + $y) % 3; + } + + /** + * mask4 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask4($x, $y) { + return (((int)($y / 2)) + ((int)($x / 3))) & 1; + } + + /** + * mask5 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask5($x, $y) { + return (($x * $y) & 1) + ($x * $y) % 3; + } + + /** + * mask6 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask6($x, $y) { + return ((($x * $y) & 1) + ($x * $y) % 3) & 1; + } + + /** + * mask7 + * @param int $x X position + * @param int $y Y position + * @return int mask + */ + protected function mask7($x, $y) { + return ((($x * $y) % 3) + (($x + $y) & 1)) & 1; + } + + /** + * Return bitmask + * @param int $maskNo mask number + * @param int $width width + * @param array $frame frame + * @return array bitmask + */ + protected function generateMaskNo($maskNo, $width, $frame) { + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + for ($y=0; $y<$width; ++$y) { + for ($x=0; $x<$width; ++$x) { + if (ord($frame[$y][$x]) & 0x80) { + $bitMask[$y][$x] = 0; + } else { + $maskFunc = call_user_func(array($this, 'mask'.$maskNo), $x, $y); + $bitMask[$y][$x] = ($maskFunc == 0)?1:0; + } + } + } + return $bitMask; + } + + /** + * makeMaskNo + * @param int $maskNo + * @param int $width + * @param int $s + * @param int $d + * @param boolean $maskGenOnly + * @return int b + */ + protected function makeMaskNo($maskNo, $width, $s, &$d, $maskGenOnly=false) { + $b = 0; + $bitMask = array(); + $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); + if ($maskGenOnly) { + return; + } + $d = $s; + for ($y=0; $y<$width; ++$y) { + for ($x=0; $x<$width; ++$x) { + if ($bitMask[$y][$x] == 1) { + $d[$y][$x] = chr(ord($s[$y][$x]) ^ (int)$bitMask[$y][$x]); + } + $b += (int)(ord($d[$y][$x]) & 1); + } + } + return $b; + } + + /** + * makeMask + * @param int $width + * @param array $frame + * @param int $maskNo + * @param int $level + * @return array mask + */ + protected function makeMask($width, $frame, $maskNo, $level) { + $masked = array_fill(0, $width, str_repeat("\0", $width)); + $this->makeMaskNo($maskNo, $width, $frame, $masked); + $this->writeFormatInformation($width, $masked, $maskNo, $level); + return $masked; + } + + /** + * calcN1N3 + * @param int $length + * @return int demerit + */ + protected function calcN1N3($length) { + $demerit = 0; + for ($i=0; $i<$length; ++$i) { + if ($this->runLength[$i] >= 5) { + $demerit += (N1 + ($this->runLength[$i] - 5)); + } + if ($i & 1) { + if (($i >= 3) AND ($i < ($length-2)) AND ($this->runLength[$i] % 3 == 0)) { + $fact = (int)($this->runLength[$i] / 3); + if (($this->runLength[$i-2] == $fact) + AND ($this->runLength[$i-1] == $fact) + AND ($this->runLength[$i+1] == $fact) + AND ($this->runLength[$i+2] == $fact)) { + if (($this->runLength[$i-3] < 0) OR ($this->runLength[$i-3] >= (4 * $fact))) { + $demerit += N3; + } elseif ((($i+3) >= $length) OR ($this->runLength[$i+3] >= (4 * $fact))) { + $demerit += N3; + } + } + } + } + } + return $demerit; + } + + /** + * evaluateSymbol + * @param int $width + * @param array $frame + * @return int demerit + */ + protected function evaluateSymbol($width, $frame) { + $head = 0; + $demerit = 0; + for ($y=0; $y<$width; ++$y) { + $head = 0; + $this->runLength[0] = 1; + $frameY = $frame[$y]; + if ($y > 0) { + $frameYM = $frame[$y-1]; + } + for ($x=0; $x<$width; ++$x) { + if (($x > 0) AND ($y > 0)) { + $b22 = ord($frameY[$x]) & ord($frameY[$x-1]) & ord($frameYM[$x]) & ord($frameYM[$x-1]); + $w22 = ord($frameY[$x]) | ord($frameY[$x-1]) | ord($frameYM[$x]) | ord($frameYM[$x-1]); + if (($b22 | ($w22 ^ 1)) & 1) { + $demerit += N2; + } + } + if (($x == 0) AND (ord($frameY[$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } elseif ($x > 0) { + if ((ord($frameY[$x]) ^ ord($frameY[$x-1])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + $demerit += $this->calcN1N3($head+1); + } + for ($x=0; $x<$width; ++$x) { + $head = 0; + $this->runLength[0] = 1; + for ($y=0; $y<$width; ++$y) { + if (($y == 0) AND (ord($frame[$y][$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } elseif ($y > 0) { + if ((ord($frame[$y][$x]) ^ ord($frame[$y-1][$x])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + $demerit += $this->calcN1N3($head+1); + } + return $demerit; + } + + /** + * mask + * @param int $width + * @param array $frame + * @param int $level + * @return array best mask + */ + protected function mask($width, $frame, $level) { + $minDemerit = PHP_INT_MAX; + $bestMaskNum = 0; + $bestMask = array(); + $checked_masks = array(0, 1, 2, 3, 4, 5, 6, 7); + if (QR_FIND_FROM_RANDOM !== false) { + $howManuOut = 8 - (QR_FIND_FROM_RANDOM % 9); + for ($i = 0; $i < $howManuOut; ++$i) { + $remPos = rand (0, count($checked_masks)-1); + unset($checked_masks[$remPos]); + $checked_masks = array_values($checked_masks); + } + } + $bestMask = $frame; + foreach ($checked_masks as $i) { + $mask = array_fill(0, $width, str_repeat("\0", $width)); + $demerit = 0; + $blacks = 0; + $blacks = $this->makeMaskNo($i, $width, $frame, $mask); + $blacks += $this->writeFormatInformation($width, $mask, $i, $level); + $blacks = (int)(100 * $blacks / ($width * $width)); + $demerit = (int)((int)(abs($blacks - 50) / 5) * N4); + $demerit += $this->evaluateSymbol($width, $mask); + if ($demerit < $minDemerit) { + $minDemerit = $demerit; + $bestMask = $mask; + $bestMaskNum = $i; + } + } + return $bestMask; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRsplit + + /** + * Return true if the character at specified position is a number + * @param string $str string + * @param int $pos characted position + * @return boolean true of false + */ + protected function isdigitat($str, $pos) { + if ($pos >= strlen($str)) { + return false; + } + return ((ord($str[$pos]) >= ord('0'))&&(ord($str[$pos]) <= ord('9'))); + } + + /** + * Return true if the character at specified position is an alphanumeric character + * @param string $str string + * @param int $pos characted position + * @return boolean true of false + */ + protected function isalnumat($str, $pos) { + if ($pos >= strlen($str)) { + return false; + } + return ($this->lookAnTable(ord($str[$pos])) >= 0); + } + + /** + * identifyMode + * @param int $pos + * @return int mode + */ + protected function identifyMode($pos) { + if ($pos >= strlen($this->dataStr)) { + return QR_MODE_NL; + } + $c = $this->dataStr[$pos]; + if ($this->isdigitat($this->dataStr, $pos)) { + return QR_MODE_NM; + } elseif ($this->isalnumat($this->dataStr, $pos)) { + return QR_MODE_AN; + } elseif ($this->hint == QR_MODE_KJ) { + if ($pos+1 < strlen($this->dataStr)) { + $d = $this->dataStr[$pos+1]; + $word = (ord($c) << 8) | ord($d); + if (($word >= 0x8140 && $word <= 0x9ffc) OR ($word >= 0xe040 && $word <= 0xebbf)) { + return QR_MODE_KJ; + } + } + } + return QR_MODE_8B; + } + + /** + * eatNum + * @return int run + */ + protected function eatNum() { + $ln = $this->lengthIndicator(QR_MODE_NM, $this->version); + $p = 0; + while($this->isdigitat($this->dataStr, $p)) { + $p++; + } + $run = $p; + $mode = $this->identifyMode($p); + if ($mode == QR_MODE_8B) { + $dif = $this->estimateBitsModeNum($run) + 4 + $ln + + $this->estimateBitsMode8(1) // + 4 + l8 + - $this->estimateBitsMode8($run + 1); // - 4 - l8 + if ($dif > 0) { + return $this->eat8(); + } + } + if ($mode == QR_MODE_AN) { + $dif = $this->estimateBitsModeNum($run) + 4 + $ln + + $this->estimateBitsModeAn(1) // + 4 + la + - $this->estimateBitsModeAn($run + 1);// - 4 - la + if ($dif > 0) { + return $this->eatAn(); + } + } + $this->items = $this->appendNewInputItem($this->items, QR_MODE_NM, $run, str_split($this->dataStr)); + return $run; + } + + /** + * eatAn + * @return int run + */ + protected function eatAn() { + $la = $this->lengthIndicator(QR_MODE_AN, $this->version); + $ln = $this->lengthIndicator(QR_MODE_NM, $this->version); + $p = 0; + while($this->isalnumat($this->dataStr, $p)) { + if ($this->isdigitat($this->dataStr, $p)) { + $q = $p; + while($this->isdigitat($this->dataStr, $q)) { + $q++; + } + $dif = $this->estimateBitsModeAn($p) // + 4 + la + + $this->estimateBitsModeNum($q - $p) + 4 + $ln + - $this->estimateBitsModeAn($q); // - 4 - la + if ($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + $run = $p; + if (!$this->isalnumat($this->dataStr, $p)) { + $dif = $this->estimateBitsModeAn($run) + 4 + $la + + $this->estimateBitsMode8(1) // + 4 + l8 + - $this->estimateBitsMode8($run + 1); // - 4 - l8 + if ($dif > 0) { + return $this->eat8(); + } + } + $this->items = $this->appendNewInputItem($this->items, QR_MODE_AN, $run, str_split($this->dataStr)); + return $run; + } + + /** + * eatKanji + * @return int run + */ + protected function eatKanji() { + $p = 0; + while($this->identifyMode($p) == QR_MODE_KJ) { + $p += 2; + } + $this->items = $this->appendNewInputItem($this->items, QR_MODE_KJ, $p, str_split($this->dataStr)); + return $run; + } + + /** + * eat8 + * @return int run + */ + protected function eat8() { + $la = $this->lengthIndicator(QR_MODE_AN, $this->version); + $ln = $this->lengthIndicator(QR_MODE_NM, $this->version); + $p = 1; + $dataStrLen = strlen($this->dataStr); + while($p < $dataStrLen) { + $mode = $this->identifyMode($p); + if ($mode == QR_MODE_KJ) { + break; + } + if ($mode == QR_MODE_NM) { + $q = $p; + while($this->isdigitat($this->dataStr, $q)) { + $q++; + } + $dif = $this->estimateBitsMode8($p) // + 4 + l8 + + $this->estimateBitsModeNum($q - $p) + 4 + $ln + - $this->estimateBitsMode8($q); // - 4 - l8 + if ($dif < 0) { + break; + } else { + $p = $q; + } + } elseif ($mode == QR_MODE_AN) { + $q = $p; + while($this->isalnumat($this->dataStr, $q)) { + $q++; + } + $dif = $this->estimateBitsMode8($p) // + 4 + l8 + + $this->estimateBitsModeAn($q - $p) + 4 + $la + - $this->estimateBitsMode8($q); // - 4 - l8 + if ($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + $run = $p; + $this->items = $this->appendNewInputItem($this->items, QR_MODE_8B, $run, str_split($this->dataStr)); + return $run; + } + + /** + * splitString + */ + protected function splitString() { + while (strlen($this->dataStr) > 0) { + if ($this->dataStr == '') { + return 0; + } + $mode = $this->identifyMode(0); + switch ($mode) { + case QR_MODE_NM: { + $length = $this->eatNum(); + break; + } + case QR_MODE_AN: { + $length = $this->eatAn(); + break; + } + case QR_MODE_KJ: { + if ($hint == QR_MODE_KJ) { + $length = $this->eatKanji(); + } else { + $length = $this->eat8(); + } + break; + } + default: { + $length = $this->eat8(); + break; + } + } + if ($length == 0) { + return 0; + } + if ($length < 0) { + return -1; + } + $this->dataStr = substr($this->dataStr, $length); + } + } + + /** + * toUpper + */ + protected function toUpper() { + $stringLen = strlen($this->dataStr); + $p = 0; + while ($p < $stringLen) { + $mode = $this->identifyMode(substr($this->dataStr, $p), $this->hint); + if ($mode == QR_MODE_KJ) { + $p += 2; + } else { + if ((ord($this->dataStr[$p]) >= ord('a')) AND (ord($this->dataStr[$p]) <= ord('z'))) { + $this->dataStr[$p] = chr(ord($this->dataStr[$p]) - 32); + } + $p++; + } + } + return $this->dataStr; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRinputItem + + /** + * newInputItem + * @param int $mode + * @param int $size + * @param array $data + * @param array $bstream + * @return array input item + */ + protected function newInputItem($mode, $size, $data, $bstream=null) { + $setData = array_slice($data, 0, $size); + if (count($setData) < $size) { + $setData = array_merge($setData, array_fill(0, ($size - count($setData)), 0)); + } + if (!$this->check($mode, $size, $setData)) { + return NULL; + } + $inputitem = array(); + $inputitem['mode'] = $mode; + $inputitem['size'] = $size; + $inputitem['data'] = $setData; + $inputitem['bstream'] = $bstream; + return $inputitem; + } + + /** + * encodeModeNum + * @param array $inputitem + * @param int $version + * @return array input item + */ + protected function encodeModeNum($inputitem, $version) { + $words = (int)($inputitem['size'] / 3); + $inputitem['bstream'] = array(); + $val = 0x1; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, $val); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], $this->lengthIndicator(QR_MODE_NM, $version), $inputitem['size']); + for ($i=0; $i < $words; ++$i) { + $val = (ord($inputitem['data'][$i*3 ]) - ord('0')) * 100; + $val += (ord($inputitem['data'][$i*3+1]) - ord('0')) * 10; + $val += (ord($inputitem['data'][$i*3+2]) - ord('0')); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 10, $val); + } + if ($inputitem['size'] - $words * 3 == 1) { + $val = ord($inputitem['data'][$words*3]) - ord('0'); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, $val); + } elseif (($inputitem['size'] - ($words * 3)) == 2) { + $val = (ord($inputitem['data'][$words*3 ]) - ord('0')) * 10; + $val += (ord($inputitem['data'][$words*3+1]) - ord('0')); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 7, $val); + } + return $inputitem; + } + + /** + * encodeModeAn + * @param array $inputitem + * @param int $version + * @return array input item + */ + protected function encodeModeAn($inputitem, $version) { + $words = (int)($inputitem['size'] / 2); + $inputitem['bstream'] = array(); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x02); + $inputitem['bstream'] = $this->appendNum(v, $this->lengthIndicator(QR_MODE_AN, $version), $inputitem['size']); + for ($i=0; $i < $words; ++$i) { + $val = (int)$this->lookAnTable(ord($inputitem['data'][$i*2 ])) * 45; + $val += (int)$this->lookAnTable(ord($inputitem['data'][$i*2+1])); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 11, $val); + } + if ($inputitem['size'] & 1) { + $val = $this->lookAnTable(ord($inputitem['data'][($words * 2)])); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 6, $val); + } + return $inputitem; + } + + /** + * encodeMode8 + * @param array $inputitem + * @param int $version + * @return array input item + */ + protected function encodeMode8($inputitem, $version) { + $inputitem['bstream'] = array(); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x4); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], $this->lengthIndicator(QR_MODE_8B, $version), $inputitem['size']); + for ($i=0; $i < $inputitem['size']; ++$i) { + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 8, ord($inputitem['data'][$i])); + } + return $inputitem; + } + + /** + * encodeModeKanji + * @param array $inputitem + * @param int $version + * @return array input item + */ + protected function encodeModeKanji($inputitem, $version) { + $inputitem['bstream'] = array(); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x8); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], $this->lengthIndicator(QR_MODE_KJ, $version), (int)($inputitem['size'] / 2)); + for ($i=0; $i<$inputitem['size']; $i+=2) { + $val = (ord($inputitem['data'][$i]) << 8) | ord($inputitem['data'][$i+1]); + if ($val <= 0x9ffc) { + $val -= 0x8140; + } else { + $val -= 0xc140; + } + $h = ($val >> 8) * 0xc0; + $val = ($val & 0xff) + $h; + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 13, $val); + } + return $inputitem; + } + + /** + * encodeModeStructure + * @param array $inputitem + * @return array input item + */ + protected function encodeModeStructure($inputitem) { + $inputitem['bstream'] = array(); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, 0x03); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, ord($inputitem['data'][1]) - 1); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 4, ord($inputitem['data'][0]) - 1); + $inputitem['bstream'] = $this->appendNum($inputitem['bstream'], 8, ord($inputitem['data'][2])); + return $inputitem; + } + + /** + * encodeBitStream + * @param array $inputitem + * @param int $version + * @return array input item + */ + protected function encodeBitStream($inputitem, $version) { + $inputitem['bstream'] = array(); + $words = $this->maximumWords($inputitem['mode'], $version); + if ($inputitem['size'] > $words) { + $st1 = $this->newInputItem($inputitem['mode'], $words, $inputitem['data']); + $st2 = $this->newInputItem($inputitem['mode'], $inputitem['size'] - $words, array_slice($inputitem['data'], $words)); + $st1 = $this->encodeBitStream($st1, $version); + $st2 = $this->encodeBitStream($st2, $version); + $inputitem['bstream'] = array(); + $inputitem['bstream'] = $this->appendBitstream($inputitem['bstream'], $st1['bstream']); + $inputitem['bstream'] = $this->appendBitstream($inputitem['bstream'], $st2['bstream']); + } else { + switch($inputitem['mode']) { + case QR_MODE_NM: { + $inputitem = $this->encodeModeNum($inputitem, $version); + break; + } + case QR_MODE_AN: { + $inputitem = $this->encodeModeAn($inputitem, $version); + break; + } + case QR_MODE_8B: { + $inputitem = $this->encodeMode8($inputitem, $version); + break; + } + case QR_MODE_KJ: { + $inputitem = $this->encodeModeKanji($inputitem, $version); + break; + } + case QR_MODE_ST: { + $inputitem = $this->encodeModeStructure($inputitem); + break; + } + default: { + break; + } + } + } + return $inputitem; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRinput + + /** + * Append data to an input object. + * The data is copied and appended to the input object. + * @param array items input items + * @param int $mode encoding mode. + * @param int $size size of data (byte). + * @param array $data array of input data. + * @return items + * + */ + protected function appendNewInputItem($items, $mode, $size, $data) { + $items[] = $this->newInputItem($mode, $size, $data); + return $items; + } + + /** + * insertStructuredAppendHeader + * @param array $items + * @param int $size + * @param int $index + * @param int $parity + * @return array items + */ + protected function insertStructuredAppendHeader($items, $size, $index, $parity) { + if ($size > MAX_STRUCTURED_SYMBOLS) { + return -1; + } + if (($index <= 0) OR ($index > MAX_STRUCTURED_SYMBOLS)) { + return -1; + } + $buf = array($size, $index, $parity); + $entry = $this->newInputItem(QR_MODE_ST, 3, buf); + array_unshift($items, $entry); + return $items; + } + + /** + * calcParity + * @param array $items + * @return int parity + */ + protected function calcParity($items) { + $parity = 0; + foreach ($items as $item) { + if ($item['mode'] != QR_MODE_ST) { + for ($i=$item['size']-1; $i>=0; --$i) { + $parity ^= $item['data'][$i]; + } + } + } + return $parity; + } + + /** + * checkModeNum + * @param int $size + * @param array $data + * @return boolean true or false + */ + protected function checkModeNum($size, $data) { + for ($i=0; $i<$size; ++$i) { + if ((ord($data[$i]) < ord('0')) OR (ord($data[$i]) > ord('9'))){ + return false; + } + } + return true; + } + + /** + * estimateBitsModeNum + * @param int $size + * @return int number of bits + */ + protected function estimateBitsModeNum($size) { + $w = (int)$size / 3; + $bits = $w * 10; + switch($size - $w * 3) { + case 1: { + $bits += 4; + break; + } + case 2: { + $bits += 7; + break; + } + default: { + break; + } + } + return $bits; + } + + /** + * Look up the alphabet-numeric convesion table (see JIS X0510:2004, pp.19). + * @param int $c character value + * @return value + */ + protected function lookAnTable($c) { + return (($c > 127)?-1:$this->anTable[$c]); + } + + /** + * checkModeAn + * @param int $size + * @param array $data + * @return boolean true or false + */ + protected function checkModeAn($size, $data) { + for ($i=0; $i<$size; ++$i) { + if ($this->lookAnTable(ord($data[$i])) == -1) { + return false; + } + } + return true; + } + + /** + * estimateBitsModeAn + * @param int $size + * @return int number of bits + */ + protected function estimateBitsModeAn($size) { + $w = (int)($size / 2); + $bits = $w * 11; + if ($size & 1) { + $bits += 6; + } + return $bits; + } + + /** + * estimateBitsMode8 + * @param int $size + * @return int number of bits + */ + protected function estimateBitsMode8($size) { + return $size * 8; + } + + /** + * estimateBitsModeKanji + * @param int $size + * @return int number of bits + */ + protected function estimateBitsModeKanji($size) { + return (int)(($size / 2) * 13); + } + + /** + * checkModeKanji + * @param int $size + * @param array $data + * @return boolean true or false + */ + protected function checkModeKanji($size, $data) { + if ($size & 1) { + return false; + } + for ($i=0; $i<$size; $i+=2) { + $val = (ord($data[$i]) << 8) | ord($data[$i+1]); + if (($val < 0x8140) OR (($val > 0x9ffc) AND ($val < 0xe040)) OR ($val > 0xebbf)) { + return false; + } + } + return true; + } + + /** + * Validate the input data. + * @param int $mode encoding mode. + * @param int $size size of data (byte). + * @param array data data to validate + * @return boolean true in case of valid data, false otherwise + */ + protected function check($mode, $size, $data) { + if ($size <= 0) { + return false; + } + switch($mode) { + case QR_MODE_NM: { + return $this->checkModeNum($size, $data); + } + case QR_MODE_AN: { + return $this->checkModeAn($size, $data); + } + case QR_MODE_KJ: { + return $this->checkModeKanji($size, $data); + } + case QR_MODE_8B: { + return true; + } + case QR_MODE_ST: { + return true; + } + default: { + break; + } + } + return false; + } + + /** + * estimateBitStreamSize + * @param array $items + * @param int $version + * @return int bits + */ + protected function estimateBitStreamSize($items, $version) { + $bits = 0; + if ($version == 0) { + $version = 1; + } + foreach ($items as $item) { + switch($item['mode']) { + case QR_MODE_NM: { + $bits = $this->estimateBitsModeNum($item['size']); + break; + } + case QR_MODE_AN: { + $bits = $this->estimateBitsModeAn($item['size']); + break; + } + case QR_MODE_8B: { + $bits = $this->estimateBitsMode8($item['size']); + break; + } + case QR_MODE_KJ: { + $bits = $this->estimateBitsModeKanji($item['size']); + break; + } + case QR_MODE_ST: { + return STRUCTURE_HEADER_BITS; + } + default: { + return 0; + } + } + $l = $this->lengthIndicator($item['mode'], $version); + $m = 1 << $l; + $num = (int)(($item['size'] + $m - 1) / $m); + $bits += $num * (4 + $l); + } + return $bits; + } + + /** + * estimateVersion + * @param array $items + * @return int version + */ + protected function estimateVersion($items) { + $version = 0; + $prev = 0; + do { + $prev = $version; + $bits = $this->estimateBitStreamSize($items, $prev); + $version = $this->getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if ($version < 0) { + return -1; + } + } while ($version > $prev); + return $version; + } + + /** + * lengthOfCode + * @param int $mode + * @param int $version + * @param int $bits + * @return int size + */ + protected function lengthOfCode($mode, $version, $bits) { + $payload = $bits - 4 - $this->lengthIndicator($mode, $version); + switch($mode) { + case QR_MODE_NM: { + $chunks = (int)($payload / 10); + $remain = $payload - $chunks * 10; + $size = $chunks * 3; + if ($remain >= 7) { + $size += 2; + } elseif ($remain >= 4) { + $size += 1; + } + break; + } + case QR_MODE_AN: { + $chunks = (int)($payload / 11); + $remain = $payload - $chunks * 11; + $size = $chunks * 2; + if ($remain >= 6) { + ++$size; + } + break; + } + case QR_MODE_8B: { + $size = (int)($payload / 8); + break; + } + case QR_MODE_KJ: { + $size = (int)(($payload / 13) * 2); + break; + } + case QR_MODE_ST: { + $size = (int)($payload / 8); + break; + } + default: { + $size = 0; + break; + } + } + $maxsize = $this->maximumWords($mode, $version); + if ($size < 0) { + $size = 0; + } + if ($size > $maxsize) { + $size = $maxsize; + } + return $size; + } + + /** + * createBitStream + * @param array $items + * @return array of items and total bits + */ + protected function createBitStream($items) { + $total = 0; + foreach ($items as $key => $item) { + $items[$key] = $this->encodeBitStream($item, $this->version); + $bits = count($items[$key]['bstream']); + $total += $bits; + } + return array($items, $total); + } + + /** + * convertData + * @param array $items + * @return array items + */ + protected function convertData($items) { + $ver = $this->estimateVersion($items); + if ($ver > $this->version) { + $this->version = $ver; + } + for (;;) { + $cbs = $this->createBitStream($items); + $items = $cbs[0]; + $bits = $cbs[1]; + if ($bits < 0) { + return -1; + } + $ver = $this->getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if ($ver < 0) { + return -1; + } elseif ($ver > $this->version) { + $this->version = $ver; + } else { + break; + } + } + return $items; + } + + /** + * Append Padding Bit to bitstream + * @param array $bstream + * @return array bitstream + */ + protected function appendPaddingBit($bstream) { + $bits = count($bstream); + $maxwords = $this->getDataLength($this->version, $this->level); + $maxbits = $maxwords * 8; + if ($maxbits == $bits) { + return 0; + } + if ($maxbits - $bits < 5) { + return $this->appendNum($bstream, $maxbits - $bits, 0); + } + $bits += 4; + $words = (int)(($bits + 7) / 8); + $padding = array(); + $padding = $this->appendNum($padding, $words * 8 - $bits + 4, 0); + $padlen = $maxwords - $words; + if ($padlen > 0) { + $padbuf = array(); + for ($i=0; $i<$padlen; ++$i) { + $padbuf[$i] = ($i&1)?0x11:0xec; + } + $padding = $this->appendBytes($padding, $padlen, $padbuf); + } + return $this->appendBitstream($bstream, $padding); + } + + /** + * mergeBitStream + * @param array $bstream + * @return array bitstream + */ + protected function mergeBitStream($items) { + $items = $this->convertData($items); + $bstream = array(); + foreach ($items as $item) { + $bstream = $this->appendBitstream($bstream, $item['bstream']); + } + return $bstream; + } + + /** + * Returns a stream of bits. + * @param int $items + * @return array padded merged byte stream + */ + protected function getBitStream($items) { + $bstream = $this->mergeBitStream($items); + return $this->appendPaddingBit($bstream); + } + + /** + * Pack all bit streams padding bits into a byte array. + * @param int $items + * @return array padded merged byte stream + */ + protected function getByteStream($items) { + $bstream = $this->getBitStream($items); + return $this->bitstreamToByte($bstream); + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRbitstream + + /** + * Return an array with zeros + * @param int $setLength array size + * @return array + */ + protected function allocate($setLength) { + return array_fill(0, $setLength, 0); + } + + /** + * Return new bitstream from number + * @param int $bits number of bits + * @param int $num number + * @return array bitstream + */ + protected function newFromNum($bits, $num) { + $bstream = $this->allocate($bits); + $mask = 1 << ($bits - 1); + for ($i=0; $i<$bits; ++$i) { + if ($num & $mask) { + $bstream[$i] = 1; + } else { + $bstream[$i] = 0; + } + $mask = $mask >> 1; + } + return $bstream; + } + + /** + * Return new bitstream from bytes + * @param int $size size + * @param array $data bytes + * @return array bitstream + */ + protected function newFromBytes($size, $data) { + $bstream = $this->allocate($size * 8); + $p=0; + for ($i=0; $i<$size; ++$i) { + $mask = 0x80; + for ($j=0; $j<8; ++$j) { + if ($data[$i] & $mask) { + $bstream[$p] = 1; + } else { + $bstream[$p] = 0; + } + $p++; + $mask = $mask >> 1; + } + } + return $bstream; + } + + /** + * Append one bitstream to another + * @param array $bitstream original bitstream + * @param array $append bitstream to append + * @return array bitstream + */ + protected function appendBitstream($bitstream, $append) { + if ((!is_array($append)) OR (count($append) == 0)) { + return $bitstream; + } + if (count($bitstream) == 0) { + return $append; + } + return array_values(array_merge($bitstream, $append)); + } + + /** + * Append one bitstream created from number to another + * @param array $bitstream original bitstream + * @param int $bits number of bits + * @param int $num number + * @return array bitstream + */ + protected function appendNum($bitstream, $bits, $num) { + if ($bits == 0) { + return 0; + } + $b = $this->newFromNum($bits, $num); + return $this->appendBitstream($bitstream, $b); + } + + /** + * Append one bitstream created from bytes to another + * @param array $bitstream original bitstream + * @param int $size size + * @param array $data bytes + * @return array bitstream + */ + protected function appendBytes($bitstream, $size, $data) { + if ($size == 0) { + return 0; + } + $b = $this->newFromBytes($size, $data); + return $this->appendBitstream($bitstream, $b); + } + + /** + * Convert bitstream to bytes + * @param array $bitstream original bitstream + * @return array of bytes + */ + protected function bitstreamToByte($bstream) { + $size = count($bstream); + if ($size == 0) { + return array(); + } + $data = array_fill(0, (int)(($size + 7) / 8), 0); + $bytes = (int)($size / 8); + $p = 0; + for ($i=0; $i<$bytes; $i++) { + $v = 0; + for ($j=0; $j<8; $j++) { + $v = $v << 1; + $v |= $bstream[$p]; + $p++; + } + $data[$i] = $v; + } + if ($size & 7) { + $v = 0; + for ($j=0; $j<($size & 7); $j++) { + $v = $v << 1; + $v |= $bstream[$p]; + $p++; + } + $data[$bytes] = $v; + } + return $data; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRspec + + /** + * Replace a value on the array at the specified position + * @param array $srctab + * @param int $x X position + * @param int $y Y position + * @param string $repl value to replace + * @param int $replLen length of the repl string + * @return array srctab + */ + protected function qrstrset($srctab, $x, $y, $repl, $replLen=false) { + $srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false)?$replLen:strlen($repl)); + return $srctab; + } + + /** + * Return maximum data code length (bytes) for the version. + * @param int $version version + * @param int $level error correction level + * @return int maximum size (bytes) + */ + protected function getDataLength($version, $level) { + return $this->capacity[$version][QRCAP_WORDS] - $this->capacity[$version][QRCAP_EC][$level]; + } + + /** + * Return maximum error correction code length (bytes) for the version. + * @param int $version version + * @param int $level error correction level + * @return int ECC size (bytes) + */ + protected function getECCLength($version, $level){ + return $this->capacity[$version][QRCAP_EC][$level]; + } + + /** + * Return the width of the symbol for the version. + * @param int $version version + * @return int width + */ + protected function getWidth($version) { + return $this->capacity[$version][QRCAP_WIDTH]; + } + + /** + * Return the numer of remainder bits. + * @param int $version version + * @return int number of remainder bits + */ + protected function getRemainder($version) { + return $this->capacity[$version][QRCAP_REMINDER]; + } + + /** + * Return a version number that satisfies the input code length. + * @param int $size input code length (byte) + * @param int $level error correction level + * @return int version number + */ + protected function getMinimumVersion($size, $level) { + for ($i=1; $i <= QRSPEC_VERSION_MAX; ++$i) { + $words = $this->capacity[$i][QRCAP_WORDS] - $this->capacity[$i][QRCAP_EC][$level]; + if ($words >= $size) { + return $i; + } + } + return -1; + } + + /** + * Return the size of length indicator for the mode and version. + * @param int $mode encoding mode + * @param int $version version + * @return int the size of the appropriate length indicator (bits). + */ + protected function lengthIndicator($mode, $version) { + if ($mode == QR_MODE_ST) { + return 0; + } + if ($version <= 9) { + $l = 0; + } elseif ($version <= 26) { + $l = 1; + } else { + $l = 2; + } + return $this->lengthTableBits[$mode][$l]; + } + + /** + * Return the maximum length for the mode and version. + * @param int $mode encoding mode + * @param int $version version + * @return int the maximum length (bytes) + */ + protected function maximumWords($mode, $version) { + if ($mode == QR_MODE_ST) { + return 3; + } + if ($version <= 9) { + $l = 0; + } else if ($version <= 26) { + $l = 1; + } else { + $l = 2; + } + $bits = $this->lengthTableBits[$mode][$l]; + $words = (1 << $bits) - 1; + if ($mode == QR_MODE_KJ) { + $words *= 2; // the number of bytes is required + } + return $words; + } + + /** + * Return an array of ECC specification. + * @param int $version version + * @param int $level error correction level + * @param array $spec an array of ECC specification contains as following: {# of type1 blocks, # of data code, # of ecc code, # of type2 blocks, # of data code} + * @return array spec + */ + protected function getEccSpec($version, $level, $spec) { + if (count($spec) < 5) { + $spec = array(0, 0, 0, 0, 0); + } + $b1 = $this->eccTable[$version][$level][0]; + $b2 = $this->eccTable[$version][$level][1]; + $data = $this->getDataLength($version, $level); + $ecc = $this->getECCLength($version, $level); + if ($b2 == 0) { + $spec[0] = $b1; + $spec[1] = (int)($data / $b1); + $spec[2] = (int)($ecc / $b1); + $spec[3] = 0; + $spec[4] = 0; + } else { + $spec[0] = $b1; + $spec[1] = (int)($data / ($b1 + $b2)); + $spec[2] = (int)($ecc / ($b1 + $b2)); + $spec[3] = $b2; + $spec[4] = $spec[1] + 1; + } + return $spec; + } + + /** + * Put an alignment marker. + * @param array $frame frame + * @param int $width width + * @param int $ox X center coordinate of the pattern + * @param int $oy Y center coordinate of the pattern + * @return array frame + */ + protected function putAlignmentMarker($frame, $ox, $oy) { + $finder = array( + "\xa1\xa1\xa1\xa1\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa0\xa1\xa0\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa1\xa1\xa1\xa1" + ); + $yStart = $oy - 2; + $xStart = $ox - 2; + for ($y=0; $y < 5; $y++) { + $frame = $this->qrstrset($frame, $xStart, $yStart+$y, $finder[$y]); + } + return $frame; + } + + /** + * Put an alignment pattern. + * @param int $version version + * @param array $fram frame + * @param int $width width + * @return array frame + */ + protected function putAlignmentPattern($version, $frame, $width) { + if ($version < 2) { + return $frame; + } + $d = $this->alignmentPattern[$version][1] - $this->alignmentPattern[$version][0]; + if ($d < 0) { + $w = 2; + } else { + $w = (int)(($width - $this->alignmentPattern[$version][0]) / $d + 2); + } + if ($w * $w - 3 == 1) { + $x = $this->alignmentPattern[$version][0]; + $y = $this->alignmentPattern[$version][0]; + $frame = $this->putAlignmentMarker($frame, $x, $y); + return $frame; + } + $cx = $this->alignmentPattern[$version][0]; + $wo = $w - 1; + for ($x=1; $x < $wo; ++$x) { + $frame = $this->putAlignmentMarker($frame, 6, $cx); + $frame = $this->putAlignmentMarker($frame, $cx, 6); + $cx += $d; + } + $cy = $this->alignmentPattern[$version][0]; + for ($y=0; $y < $wo; ++$y) { + $cx = $this->alignmentPattern[$version][0]; + for ($x=0; $x < $wo; ++$x) { + $frame = $this->putAlignmentMarker($frame, $cx, $cy); + $cx += $d; + } + $cy += $d; + } + return $frame; + } + + /** + * Return BCH encoded version information pattern that is used for the symbol of version 7 or greater. Use lower 18 bits. + * @param int $version version + * @return BCH encoded version information pattern + */ + protected function getVersionPattern($version) { + if (($version < 7) OR ($version > QRSPEC_VERSION_MAX)) { + return 0; + } + return $this->versionPattern[($version - 7)]; + } + + /** + * Return BCH encoded format information pattern. + * @param array $mask + * @param int $level error correction level + * @return BCH encoded format information pattern + */ + protected function getFormatInfo($mask, $level) { + if (($mask < 0) OR ($mask > 7)) { + return 0; + } + if (($level < 0) OR ($level > 3)) { + return 0; + } + return $this->formatInfo[$level][$mask]; + } + + /** + * Put a finder pattern. + * @param array $frame frame + * @param int $width width + * @param int $ox X center coordinate of the pattern + * @param int $oy Y center coordinate of the pattern + * @return array frame + */ + protected function putFinderPattern($frame, $ox, $oy) { + $finder = array( + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1" + ); + for ($y=0; $y < 7; $y++) { + $frame = $this->qrstrset($frame, $ox, ($oy + $y), $finder[$y]); + } + return $frame; + } + + /** + * Return a copy of initialized frame. + * @param int $version version + * @return Array of unsigned char. + */ + protected function createFrame($version) { + $width = $this->capacity[$version][QRCAP_WIDTH]; + $frameLine = str_repeat ("\0", $width); + $frame = array_fill(0, $width, $frameLine); + // Finder pattern + $frame = $this->putFinderPattern($frame, 0, 0); + $frame = $this->putFinderPattern($frame, $width - 7, 0); + $frame = $this->putFinderPattern($frame, 0, $width - 7); + // Separator + $yOffset = $width - 7; + for ($y=0; $y < 7; ++$y) { + $frame[$y][7] = "\xc0"; + $frame[$y][$width - 8] = "\xc0"; + $frame[$yOffset][7] = "\xc0"; + ++$yOffset; + } + $setPattern = str_repeat("\xc0", 8); + $frame = $this->qrstrset($frame, 0, 7, $setPattern); + $frame = $this->qrstrset($frame, $width-8, 7, $setPattern); + $frame = $this->qrstrset($frame, 0, $width - 8, $setPattern); + // Format info + $setPattern = str_repeat("\x84", 9); + $frame = $this->qrstrset($frame, 0, 8, $setPattern); + $frame = $this->qrstrset($frame, $width - 8, 8, $setPattern, 8); + $yOffset = $width - 8; + for ($y=0; $y < 8; ++$y,++$yOffset) { + $frame[$y][8] = "\x84"; + $frame[$yOffset][8] = "\x84"; + } + // Timing pattern + $wo = $width - 15; + for ($i=1; $i < $wo; ++$i) { + $frame[6][7+$i] = chr(0x90 | ($i & 1)); + $frame[7+$i][6] = chr(0x90 | ($i & 1)); + } + // Alignment pattern + $frame = $this->putAlignmentPattern($version, $frame, $width); + // Version information + if ($version >= 7) { + $vinf = $this->getVersionPattern($version); + $v = $vinf; + for ($x=0; $x<6; ++$x) { + for ($y=0; $y<3; ++$y) { + $frame[($width - 11)+$y][$x] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + $v = $vinf; + for ($y=0; $y<6; ++$y) { + for ($x=0; $x<3; ++$x) { + $frame[$y][$x+($width - 11)] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + } + // and a little bit... + $frame[$width - 8][8] = "\x81"; + return $frame; + } + + /** + * Set new frame for the specified version. + * @param int $version version + * @return Array of unsigned char. + */ + protected function newFrame($version) { + if (($version < 1) OR ($version > QRSPEC_VERSION_MAX)) { + return NULL; + } + if (!isset($this->frames[$version])) { + $this->frames[$version] = $this->createFrame($version); + } + if (is_null($this->frames[$version])) { + return NULL; + } + return $this->frames[$version]; + } + + /** + * Return block number 0 + * @param array $spec + * @return int value + */ + protected function rsBlockNum($spec) { + return ($spec[0] + $spec[3]); + } + + /** + * Return block number 1 + * @param array $spec + * @return int value + */ + protected function rsBlockNum1($spec) { + return $spec[0]; + } + + /** + * Return data codes 1 + * @param array $spec + * @return int value + */ + protected function rsDataCodes1($spec) { + return $spec[1]; + } + + /** + * Return ecc codes 1 + * @param array $spec + * @return int value + */ + protected function rsEccCodes1($spec) { + return $spec[2]; + } + + /** + * Return block number 2 + * @param array $spec + * @return int value + */ + protected function rsBlockNum2($spec) { + return $spec[3]; + } + + /** + * Return data codes 2 + * @param array $spec + * @return int value + */ + protected function rsDataCodes2($spec) { + return $spec[4]; + } + + /** + * Return ecc codes 2 + * @param array $spec + * @return int value + */ + protected function rsEccCodes2($spec) { + return $spec[2]; + } + + /** + * Return data length + * @param array $spec + * @return int value + */ + protected function rsDataLength($spec) { + return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); + } + + /** + * Return ecc length + * @param array $spec + * @return int value + */ + protected function rsEccLength($spec) { + return ($spec[0] + $spec[3]) * $spec[2]; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRrs + + /** + * Initialize a Reed-Solomon codec and add it to existing rsitems + * @param int $symsize symbol size, bits + * @param int $gfpoly Field generator polynomial coefficients + * @param int $fcr first root of RS code generator polynomial, index form + * @param int $prim primitive element to generate polynomial roots + * @param int $nroots RS code generator polynomial degree (number of roots) + * @param int $pad padding bytes at front of shortened block + * @return array Array of RS values:
  • mm = Bits per symbol;
  • nn = Symbols per block;
  • alpha_to = log lookup table array;
  • index_of = Antilog lookup table array;
  • genpoly = Generator polynomial array;
  • nroots = Number of generator;
  • roots = number of parity symbols;
  • fcr = First consecutive root, index form;
  • prim = Primitive element, index form;
  • iprim = prim-th root of 1, index form;
  • pad = Padding bytes in shortened block;
  • gfpoly
. + */ + protected function init_rs($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) { + foreach ($this->rsitems as $rs) { + if (($rs['pad'] != $pad) OR ($rs['nroots'] != $nroots) OR ($rs['mm'] != $symsize) + OR ($rs['gfpoly'] != $gfpoly) OR ($rs['fcr'] != $fcr) OR ($rs['prim'] != $prim)) { + continue; + } + return $rs; + } + $rs = $this->init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad); + array_unshift($this->rsitems, $rs); + return $rs; + } + + // - - - - - - - - - - - - - - - - - - - - - - - - - + + // QRrsItem + + /** + * modnn + * @param array RS values + * @param int $x X position + * @return int X osition + */ + protected function modnn($rs, $x) { + while ($x >= $rs['nn']) { + $x -= $rs['nn']; + $x = ($x >> $rs['mm']) + ($x & $rs['nn']); + } + return $x; + } + + /** + * Initialize a Reed-Solomon codec and returns an array of values. + * @param int $symsize symbol size, bits + * @param int $gfpoly Field generator polynomial coefficients + * @param int $fcr first root of RS code generator polynomial, index form + * @param int $prim primitive element to generate polynomial roots + * @param int $nroots RS code generator polynomial degree (number of roots) + * @param int $pad padding bytes at front of shortened block + * @return array Array of RS values:
  • mm = Bits per symbol;
  • nn = Symbols per block;
  • alpha_to = log lookup table array;
  • index_of = Antilog lookup table array;
  • genpoly = Generator polynomial array;
  • nroots = Number of generator;
  • roots = number of parity symbols;
  • fcr = First consecutive root, index form;
  • prim = Primitive element, index form;
  • iprim = prim-th root of 1, index form;
  • pad = Padding bytes in shortened block;
  • gfpoly
. + */ + protected function init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) { + // Based on Reed solomon encoder by Phil Karn, KA9Q (GNU-LGPLv2) + $rs = null; + // Check parameter ranges + if (($symsize < 0) OR ($symsize > 8)) { + return $rs; + } + if (($fcr < 0) OR ($fcr >= (1<<$symsize))) { + return $rs; + } + if (($prim <= 0) OR ($prim >= (1<<$symsize))) { + return $rs; + } + if (($nroots < 0) OR ($nroots >= (1<<$symsize))) { + return $rs; + } + if (($pad < 0) OR ($pad >= ((1<<$symsize) -1 - $nroots))) { + return $rs; + } + $rs = array(); + $rs['mm'] = $symsize; + $rs['nn'] = (1 << $symsize) - 1; + $rs['pad'] = $pad; + $rs['alpha_to'] = array_fill(0, ($rs['nn'] + 1), 0); + $rs['index_of'] = array_fill(0, ($rs['nn'] + 1), 0); + // PHP style macro replacement ;) + $NN =& $rs['nn']; + $A0 =& $NN; + // Generate Galois field lookup tables + $rs['index_of'][0] = $A0; // log(zero) = -inf + $rs['alpha_to'][$A0] = 0; // alpha**-inf = 0 + $sr = 1; + for ($i=0; $i<$rs['nn']; ++$i) { + $rs['index_of'][$sr] = $i; + $rs['alpha_to'][$i] = $sr; + $sr <<= 1; + if ($sr & (1 << $symsize)) { + $sr ^= $gfpoly; + } + $sr &= $rs['nn']; + } + if ($sr != 1) { + // field generator polynomial is not primitive! + return NULL; + } + // Form RS code generator polynomial from its roots + $rs['genpoly'] = array_fill(0, ($nroots + 1), 0); + $rs['fcr'] = $fcr; + $rs['prim'] = $prim; + $rs['nroots'] = $nroots; + $rs['gfpoly'] = $gfpoly; + // Find prim-th root of 1, used in decoding + for ($iprim=1; ($iprim % $prim) != 0; $iprim += $rs['nn']) { + ; // intentional empty-body loop! + } + $rs['iprim'] = (int)($iprim / $prim); + $rs['genpoly'][0] = 1; + + + for ($i = 0,$root=$fcr*$prim; $i < $nroots; $i++, $root += $prim) { + $rs['genpoly'][$i+1] = 1; + // Multiply rs->genpoly[] by @**(root + x) + for ($j = $i; $j > 0; --$j) { + if ($rs['genpoly'][$j] != 0) { + $rs['genpoly'][$j] = $rs['genpoly'][$j-1] ^ $rs['alpha_to'][$this->modnn($rs, $rs['index_of'][$rs['genpoly'][$j]] + $root)]; + } else { + $rs['genpoly'][$j] = $rs['genpoly'][$j-1]; + } + } + // rs->genpoly[0] can never be zero + $rs['genpoly'][0] = $rs['alpha_to'][$this->modnn($rs, $rs['index_of'][$rs['genpoly'][0]] + $root)]; + } + // convert rs->genpoly[] to index form for quicker encoding + for ($i = 0; $i <= $nroots; ++$i) { + $rs['genpoly'][$i] = $rs['index_of'][$rs['genpoly'][$i]]; + } + return $rs; + } + + /** + * Encode a Reed-Solomon codec and returns the parity array + * @param array $rs RS values + * @param array $data data + * @param array $parity parity + * @return parity array + */ + protected function encode_rs_char($rs, $data, $parity) { + $MM =& $rs['mm']; // bits per symbol + $NN =& $rs['nn']; // the total number of symbols in a RS block + $ALPHA_TO =& $rs['alpha_to']; // the address of an array of NN elements to convert Galois field elements in index (log) form to polynomial form + $INDEX_OF =& $rs['index_of']; // the address of an array of NN elements to convert Galois field elements in polynomial form to index (log) form + $GENPOLY =& $rs['genpoly']; // an array of NROOTS+1 elements containing the generator polynomial in index form + $NROOTS =& $rs['nroots']; // the number of roots in the RS code generator polynomial, which is the same as the number of parity symbols in a block + $FCR =& $rs['fcr']; // first consecutive root, index form + $PRIM =& $rs['prim']; // primitive element, index form + $IPRIM =& $rs['iprim']; // prim-th root of 1, index form + $PAD =& $rs['pad']; // the number of pad symbols in a block + $A0 =& $NN; + $parity = array_fill(0, $NROOTS, 0); + for ($i=0; $i < ($NN - $NROOTS - $PAD); $i++) { + $feedback = $INDEX_OF[$data[$i] ^ $parity[0]]; + if ($feedback != $A0) { + // feedback term is non-zero + // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must + // always be for the polynomials constructed by init_rs() + $feedback = $this->modnn($rs, $NN - $GENPOLY[$NROOTS] + $feedback); + for ($j=1; $j < $NROOTS; ++$j) { + $parity[$j] ^= $ALPHA_TO[$this->modnn($rs, $feedback + $GENPOLY[($NROOTS - $j)])]; + } + } + // Shift + array_shift($parity); + if ($feedback != $A0) { + array_push($parity, $ALPHA_TO[$this->modnn($rs, $feedback + $GENPOLY[0])]); + } else { + array_push($parity, 0); + } + } + return $parity; + } + + } // end QRcode class + +} // END OF "class_exists QRcode" +?> diff --git a/src-backup/includes/phpqrcode/cache/frame_1.dat b/src-backup/includes/phpqrcode/cache/frame_1.dat new file mode 100644 index 0000000..be28fea --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_1.dat @@ -0,0 +1,2 @@ +xڝ E9u`"PńC牗T!0$ +EɲQmh۾9{kI" 9Ln)Ap־>^zmnŖ;mn \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_1.png b/src-backup/includes/phpqrcode/cache/frame_1.png new file mode 100644 index 0000000..86ce6e9 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_1.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_10.dat b/src-backup/includes/phpqrcode/cache/frame_10.dat new file mode 100644 index 0000000..aff163f Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_10.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_10.png b/src-backup/includes/phpqrcode/cache/frame_10.png new file mode 100644 index 0000000..dbfcd70 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_10.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_11.dat b/src-backup/includes/phpqrcode/cache/frame_11.dat new file mode 100644 index 0000000..95af68a Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_11.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_11.png b/src-backup/includes/phpqrcode/cache/frame_11.png new file mode 100644 index 0000000..c07c761 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_11.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_12.dat b/src-backup/includes/phpqrcode/cache/frame_12.dat new file mode 100644 index 0000000..73228b3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_12.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_12.png b/src-backup/includes/phpqrcode/cache/frame_12.png new file mode 100644 index 0000000..8ba6782 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_12.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_13.dat b/src-backup/includes/phpqrcode/cache/frame_13.dat new file mode 100644 index 0000000..2256f0e Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_13.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_13.png b/src-backup/includes/phpqrcode/cache/frame_13.png new file mode 100644 index 0000000..6e49d35 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_13.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_14.dat b/src-backup/includes/phpqrcode/cache/frame_14.dat new file mode 100644 index 0000000..e9ae093 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_14.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_14.png b/src-backup/includes/phpqrcode/cache/frame_14.png new file mode 100644 index 0000000..efc36c0 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_14.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_15.dat b/src-backup/includes/phpqrcode/cache/frame_15.dat new file mode 100644 index 0000000..1872781 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_15.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_15.png b/src-backup/includes/phpqrcode/cache/frame_15.png new file mode 100644 index 0000000..a9f416c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_15.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_16.dat b/src-backup/includes/phpqrcode/cache/frame_16.dat new file mode 100644 index 0000000..60af678 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_16.dat @@ -0,0 +1 @@ +xA E]sIX;n6`qW6`%A/3!!g̡1N) E|;>6⸏97$c]kkw1[mC͜cR>E,hʼnp#xFyWVWG3+˓S}Ğ#G8b^c^cpc&3YQ"vk9܇} ĿQL/ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_16.png b/src-backup/includes/phpqrcode/cache/frame_16.png new file mode 100644 index 0000000..6ac8fe8 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_16.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_17.dat b/src-backup/includes/phpqrcode/cache/frame_17.dat new file mode 100644 index 0000000..87f0cf5 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_17.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_17.png b/src-backup/includes/phpqrcode/cache/frame_17.png new file mode 100644 index 0000000..5b929ac Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_17.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_18.dat b/src-backup/includes/phpqrcode/cache/frame_18.dat new file mode 100644 index 0000000..bb7138c --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_18.dat @@ -0,0 +1,2 @@ +xA +0E]օ,2;s&͚hO1&09OIv@DD &ىKXFv<dq9<%h Ys !(ds;~||b(Yůg#`KSĶsidߍLg:әt/gmkM3{4rTQes><әt3;H#љt3Y+oghٽlnF>i^#awm;g~pgNs{6zp' \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_18.png b/src-backup/includes/phpqrcode/cache/frame_18.png new file mode 100644 index 0000000..ee0d6a3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_18.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_19.dat b/src-backup/includes/phpqrcode/cache/frame_19.dat new file mode 100644 index 0000000..95e26ad --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_19.dat @@ -0,0 +1,3 @@ +xA + E.No7ћiiRN2W%x@ڜ' +u6.*S;}àT zrt%,};)ZLP$qgLdJ;w.]z#[͝Og" B}};w#1Gb;w_C+w@Dfu2N9R7|pWkk \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_19.png b/src-backup/includes/phpqrcode/cache/frame_19.png new file mode 100644 index 0000000..20fddd8 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_19.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_2.dat b/src-backup/includes/phpqrcode/cache/frame_2.dat new file mode 100644 index 0000000..7e42f31 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_2.dat @@ -0,0 +1 @@ +x͒ F{v& &Y+?Z1S'y!a815&۴HٞclF1#6 f6O7C֏8gIfB\DԻ( \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_2.png b/src-backup/includes/phpqrcode/cache/frame_2.png new file mode 100644 index 0000000..9c150eb Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_2.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_20.dat b/src-backup/includes/phpqrcode/cache/frame_20.dat new file mode 100644 index 0000000..d5ecc1d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_20.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_20.png b/src-backup/includes/phpqrcode/cache/frame_20.png new file mode 100644 index 0000000..23a061d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_20.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_21.dat b/src-backup/includes/phpqrcode/cache/frame_21.dat new file mode 100644 index 0000000..1974dd9 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_21.dat @@ -0,0 +1 @@ +xA E]sIX;n6Upв]٘< i-eW)ŕ…H\jvqHL\6ЅrILܹ%@Vv(P4|Xngɝ~]Du1Us S\,2N?DKF-:eJ]p_,a0` X` w,` X]5 Y4{2vJs9)u۹,]^_7$_ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_21.png b/src-backup/includes/phpqrcode/cache/frame_21.png new file mode 100644 index 0000000..291598c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_21.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_22.dat b/src-backup/includes/phpqrcode/cache/frame_22.dat new file mode 100644 index 0000000..0f01802 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_22.dat @@ -0,0 +1,3 @@ +xA +0 E]{.]{{{ZBepwe@VERZ3"*2o4y)i#dbdF҅I"4WIu45x.ZS{8k={o.q[:帒qy +)t#N8dCj-OOG}:/:sz!)^IO- 7p 7$}>ɷ7p tssrs Vmҹ}R~7&?7ԦIbh{<Mi- \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_23.png b/src-backup/includes/phpqrcode/cache/frame_23.png new file mode 100644 index 0000000..b8f16ae Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_23.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_24.dat b/src-backup/includes/phpqrcode/cache/frame_24.dat new file mode 100644 index 0000000..7b92e29 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_24.dat @@ -0,0 +1 @@ +xA EMX0;nVP4HSSxU3/O LiJ4V JC%6VR&DBHjDJ??BlcDZ'UXUޏ0ywįj똳3ścj{:GqGNv;笓J <]#8#8H'GqGtr:9#8#8ؓhNt_>teS^\gQe?vuo;>*wlm \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_24.png b/src-backup/includes/phpqrcode/cache/frame_24.png new file mode 100644 index 0000000..397c64f Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_24.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_25.dat b/src-backup/includes/phpqrcode/cache/frame_25.dat new file mode 100644 index 0000000..ba12518 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_25.dat @@ -0,0 +1,3 @@ +xA + s낋]rxY51mMBG +*Sx|Ua5ƵZ-,1HPRjX5iG>WR/+uT廯 ӯ嗴u[Sa[kv5+5nJ%+VXbŊ߬u'SRtzZ++VXbŊٟٟٟ+VXb}Ŋ+VXVI+kq[toVZvoNVw}{r<ýR"R] Wr} \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_25.png b/src-backup/includes/phpqrcode/cache/frame_25.png new file mode 100644 index 0000000..25bc445 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_25.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_26.dat b/src-backup/includes/phpqrcode/cache/frame_26.dat new file mode 100644 index 0000000..d34a73f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_26.dat @@ -0,0 +1,2 @@ +xA + Eօ,t77ћU E)i7*~cXEBFC6:&L,Mv.KgոYM>>mۚ?vmg?ұηdCUIkE\Msfafa>[sӈ9쬩ެ8b]LgEo w1 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_26.png b/src-backup/includes/phpqrcode/cache/frame_26.png new file mode 100644 index 0000000..f4a6b39 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_26.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_27.dat b/src-backup/includes/phpqrcode/cache/frame_27.dat new file mode 100644 index 0000000..b4d9ffd Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_27.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_27.png b/src-backup/includes/phpqrcode/cache/frame_27.png new file mode 100644 index 0000000..8419ec2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_27.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_28.dat b/src-backup/includes/phpqrcode/cache/frame_28.dat new file mode 100644 index 0000000..8cbaa19 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_28.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_28.png b/src-backup/includes/phpqrcode/cache/frame_28.png new file mode 100644 index 0000000..7609d8e Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_28.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_29.dat b/src-backup/includes/phpqrcode/cache/frame_29.dat new file mode 100644 index 0000000..5e4a711 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_29.dat @@ -0,0 +1,2 @@ +xA a޺ @n7+*4!?J 抮]STf)sI"Ȕb0|"Luٸ,E1\6*uQ?>aυR-rn.ꯋ\T:*)|) , ,x_}:^RUoɢu~މX`XЏЏЏЏ_`X`XЏЏЏ_`X`XЏЏЏЏwbX`PU)D"c{z3<}^?bm잃a.] +{Q6uT,9 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_29.png b/src-backup/includes/phpqrcode/cache/frame_29.png new file mode 100644 index 0000000..ffe072c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_29.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_3.dat b/src-backup/includes/phpqrcode/cache/frame_3.dat new file mode 100644 index 0000000..188d531 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_3.dat @@ -0,0 +1 @@ +x E{v& &Y+bk'ya:TXl޶$W+ӏv9}gR@H0YPBEm?s"bt2cn:ﺭ;YzQ7 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_3.png b/src-backup/includes/phpqrcode/cache/frame_3.png new file mode 100644 index 0000000..945ee7c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_3.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_30.dat b/src-backup/includes/phpqrcode/cache/frame_30.dat new file mode 100644 index 0000000..44cf3d3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_30.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_30.png b/src-backup/includes/phpqrcode/cache/frame_30.png new file mode 100644 index 0000000..75dbddd Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_30.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_31.dat b/src-backup/includes/phpqrcode/cache/frame_31.dat new file mode 100644 index 0000000..ce429d0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_31.dat @@ -0,0 +1 @@ +xA a޺ &r4yķ!mV3Iv!Ҝ2i\NSS4EF2+65e/Ws]!?p=S~Đ?+x6r6y}ǴeR1-WllҌXz/>V櫷:ñA8-+mTbllltM&]ll&]Ill&]y 6` 6`iuyXWi\tz>.zk t77wJϔ4w҈85 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_31.png b/src-backup/includes/phpqrcode/cache/frame_31.png new file mode 100644 index 0000000..b14d1fa Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_31.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_32.dat b/src-backup/includes/phpqrcode/cache/frame_32.dat new file mode 100644 index 0000000..aaa0808 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_32.dat @@ -0,0 +1,2 @@ +x + ־. Dl, Mz6Ç gcJD;'.AIqމI,IrYFk%DOy|EDD(L_Y>*ߚ?aOkL_<[c>c˘uLI%#0#0#otѢ}4fv_)Eph5R881#0#0itZ#0#0#0itZ#0#0#0itZl0#09q"HܜHQ"L5}-Y׾k`>z鸳4&p!!`:5 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_32.png b/src-backup/includes/phpqrcode/cache/frame_32.png new file mode 100644 index 0000000..58d42db Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_32.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_33.dat b/src-backup/includes/phpqrcode/cache/frame_33.dat new file mode 100644 index 0000000..a261375 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_33.dat @@ -0,0 +1,14 @@ +xA a޺@n7+*L++柮bb*LCc kHrjJ5Yi~0_TT}e>5b_w͟?\Rai+7W\wLUNL ++ ++jOkc\˩|%o} 8 ++ ++ ++ 3g ++ ++ ++3g@ ++ ++ ++:RXB9I=ko/Swؘٯ`gr_ٙYVSYzIefnmQoz > \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_33.png b/src-backup/includes/phpqrcode/cache/frame_33.png new file mode 100644 index 0000000..924c728 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_33.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_34.dat b/src-backup/includes/phpqrcode/cache/frame_34.dat new file mode 100644 index 0000000..7ceb025 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_34.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_34.png b/src-backup/includes/phpqrcode/cache/frame_34.png new file mode 100644 index 0000000..a477042 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_34.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_35.dat b/src-backup/includes/phpqrcode/cache/frame_35.dat new file mode 100644 index 0000000..56bc3e2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_35.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_35.png b/src-backup/includes/phpqrcode/cache/frame_35.png new file mode 100644 index 0000000..d29806c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_35.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_36.dat b/src-backup/includes/phpqrcode/cache/frame_36.dat new file mode 100644 index 0000000..282c60d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_36.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_36.png b/src-backup/includes/phpqrcode/cache/frame_36.png new file mode 100644 index 0000000..96ecb42 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_36.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_37.dat b/src-backup/includes/phpqrcode/cache/frame_37.dat new file mode 100644 index 0000000..015c0f2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_37.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_37.png b/src-backup/includes/phpqrcode/cache/frame_37.png new file mode 100644 index 0000000..fcc5162 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_37.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_38.dat b/src-backup/includes/phpqrcode/cache/frame_38.dat new file mode 100644 index 0000000..71cf53e --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_38.dat @@ -0,0 +1 @@ +xA0ЎuA2;Нk(gytp9$D\e^'t-aIFMSkIŤ:7|LkN8N7i}i,[WgӴ?31iN}}=OM:4)SL2eʔ)SL#$ JJM:}]L٧SQL2eʔ)SL2աPt(:)SL2eʔ)S:ECq2eʔ)SL2eʔECѡ8O2eʔ)SL2eTCѡPL2eʔ)SL2ݓsJCIKԂi93n_ +Ri4\g;% }an \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_38.png b/src-backup/includes/phpqrcode/cache/frame_38.png new file mode 100644 index 0000000..89238f3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_38.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_39.dat b/src-backup/includes/phpqrcode/cache/frame_39.dat new file mode 100644 index 0000000..53511f7 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_39.dat differ diff --git a/src-backup/includes/phpqrcode/cache/frame_39.png b/src-backup/includes/phpqrcode/cache/frame_39.png new file mode 100644 index 0000000..1dc9cd1 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_39.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_4.dat b/src-backup/includes/phpqrcode/cache/frame_4.dat new file mode 100644 index 0000000..67b30e8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_4.dat @@ -0,0 +1 @@ +x E=u pجQCOM'ˏ$ @3eF\FNXRyؾC{a8R Ńa2@qkH1(`cj~0ܨعnXGĀ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_4.png b/src-backup/includes/phpqrcode/cache/frame_4.png new file mode 100644 index 0000000..b72f9e7 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_4.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_40.dat b/src-backup/includes/phpqrcode/cache/frame_40.dat new file mode 100644 index 0000000..90d36dd --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_40.dat @@ -0,0 +1,2 @@ +xA@Ь@o7`Qfe䕫PA><]߳bZn^AQ}[9^]ynajM܇K̘1cƌ3f̘1{W5}{7lMޚxI<Kαyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘1ۻٻ={αyl3f̘1cƌ3f̘SʑӒ7HK޼g\u_r'4[-]qL8ƝY1q!/(% \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/frame_40.png b/src-backup/includes/phpqrcode/cache/frame_40.png new file mode 100644 index 0000000..8034d86 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/frame_40.png differ diff --git a/src-backup/includes/phpqrcode/cache/frame_5.dat b/src-backup/includes/phpqrcode/cache/frame_5.dat new file mode 100644 index 0000000..d5dafe1 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/frame_5.dat @@ -0,0 +1 @@ +x1 Eu7ЛZ|ND B0@R$l,->VKZ[I9+Es=ϤL1̄[FZU4?i<;7;P#W-[ݯ6ddddddc",;"sk摑Q&erw######L.摑Иy1^˲\3 v \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_117_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_117_0.dat new file mode 100644 index 0000000..781c7f8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_117_0.dat @@ -0,0 +1,2 @@ +xA +0 }OrR,#3,o5Cq:;;wvNJZG=m} ѱ2iRkj_YYYYYYYYe_/WVVVVVVkd-Ϻ,#OZc]|{ž$ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_121_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_121_0.dat new file mode 100644 index 0000000..68810c3 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_121_0.dat @@ -0,0 +1 @@ +x1 О/w YMS8>2SFOEcW\ۼ{cpKGBКmxhfffffff/s22W|*d1*5̬RWas\xm~8߮r0wjsdm&y \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_125_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_125_0.dat new file mode 100644 index 0000000..2c73ef1 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_125_0.dat @@ -0,0 +1,2 @@ +xA + н_TH`3AOL4 k(ewGW. #2} \Ygggggggggg_d>j^s;;;;;;;;;;'q;;;;;;;;;'˰qu_PYw{e=dG/ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_129_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_129_0.dat new file mode 100644 index 0000000..812ee8a --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_129_0.dat @@ -0,0 +1,2 @@ +x1 + /*DE'hgt-}_pV \"b=s[J=8Dho۞' 0X ۴e0`  j" 0`Wf`^P0`2Ȁ  d07(Y/XLGby"pT \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_137_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_137_0.dat new file mode 100644 index 0000000..f6d993b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_137_0.dat @@ -0,0 +1 @@ +x1 О/+FZ?J L7Ժ*Ba%L~˻ʓCJYIWJ .K]R0a„ $INTwlLaL0a„ &Ld@PO0a„ &L0e@P?a„ &L0aDe@ &L0aMIlL&)dlgacR<$v,ɺ?U2] \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_141_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_141_0.dat new file mode 100644 index 0000000..8c685c8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_141_0.dat @@ -0,0 +1,2 @@ +x= +0 нi9'EDx͘%I9+E{$m^&uS"D6ڟ]98UMbҾY[2拉Ĉ#F1bĈ%iRN潝ѳ#;#F1bĈN1i#F1bĈ#FtZ}Nk1bĈ#F1bktZ;#F1bFV-u"IoD-*7uj>bMV+ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_149_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_149_0.dat new file mode 100644 index 0000000..d258350 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_149_0.dat @@ -0,0 +1,3 @@ +xA + н_MEQXP৞.|94e{JLv#^n[ ?; +ZIV-*w˒1*+VXbŊXgwqX}JRYbŊ+VXbeΠwfeΠ^bŊ+VXbʜAʜAbŊ+VXbŊ9ٜAbŊ+VXbŊl0*0Tj`?Ϊ;X=zZr* \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_153_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_153_0.dat new file mode 100644 index 0000000..fc79e9e --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_153_0.dat @@ -0,0 +1 @@ +x1 Н/礑h&F`Ҽ@I;PZ^X͌mf.=5 [if-R+!wr˜g\j̘1cƌ3f̘1cfo.2?1z `ƌ3f̘1cƌzƌ3f̘1cƌ3fztf3f̘1cƌ3f̘kk030cƌ3f̘1c9;Ď`vf͚̆ZϘW9 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_157_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_157_0.dat new file mode 100644 index 0000000..ad749f3 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_157_0.dat @@ -0,0 +1,2 @@ +xA + н_QRY k*q͵=j7~nN.p%ڵsi.رcǎ;vر{.-W2={mgy+رcǎ;vɳ2;yּcǎ;vرcNɳ;vرcǎ;v2I9+DyI4ˠ5:Wvdqߜܴ<d2x%[U%2]&K,Ydɒ%ˡ,S՗r2yd=,k_{Xdɒ%K,Yd)0m,Ydɒ%K,Yd)0m,Ydɒ%K,Yme,e%K,Ydɒ%K,eq Ò%K,Ydɒe:I9EQ=Ls I{ZtR}Sn:|R[?_*SL2eʔ)SL&ϦI O2O2eʔ)SL2e*C1PPSL2eʔ)SLP22)SL2eʔ)SLe(}2)SL2eʔ)SLe(}2)SL2eʔ)Sic7;"ޙFͦސٙvL ^2}oO'r \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_173_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_173_0.dat new file mode 100644 index 0000000..5ef85e7 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_173_0.dat @@ -0,0 +1 @@ +x10ޯT [4v2ƽok݇;Ӳ]f֞dljlG0n+߻mG˖-[lٲe"Y}oV[lٲe˖-[lٲeհՃ[2lٲe˖-[lٲeհՃ[2lٲe˖-[lٲeհՃ[lٲe˖-[lٲeValٲe˖-[lٲef[BmаE;N-ۜT/rl?* \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_177_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_177_0.dat new file mode 100644 index 0000000..78a26a7 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_177_0.dat @@ -0,0 +1,2 @@ +x1 +0>I9+?߁iև d̹xֈxN/է|{ظ8d0h=cFf̘1cƌ3f̘qq=w6;l4cƕ<nj3f̘1cƌ3fXһ1ֻcƌ3f̘1cƌ3fXbwnj3f̘1cƌ3f̘M'X&1cƌ3f̘1cƌ3ֻnn1cƌ3f̘1cƌÍ3U< \7+(<OƌΊnj4@ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_21_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_21_0.dat new file mode 100644 index 0000000..368c994 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_21_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_25_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_25_0.dat new file mode 100644 index 0000000..e4a5b6d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_25_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_29_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_29_0.dat new file mode 100644 index 0000000..74a216b Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_29_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_33_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_33_0.dat new file mode 100644 index 0000000..2ec712a Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_33_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_37_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_37_0.dat new file mode 100644 index 0000000..1588cfc Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_37_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_41_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_41_0.dat new file mode 100644 index 0000000..e369027 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_41_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_45_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_45_0.dat new file mode 100644 index 0000000..452f126 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_45_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_49_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_49_0.dat new file mode 100644 index 0000000..fdd2aac --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_49_0.dat @@ -0,0 +1,2 @@ +xK E9o#?H/6g$-,X] +xݘ; X԰9<Ѻq2AfH7/5We{#fި?4=N > \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_53_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_53_0.dat new file mode 100644 index 0000000..572d279 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_53_0.dat @@ -0,0 +1,2 @@ +xK +@!йoQϺ:(m&s-6Z{m4YX.F٭XZij=:έ֋b忑VH 8 #[Y^Xe \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_57_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_57_0.dat new file mode 100644 index 0000000..ea81e6d --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_57_0.dat @@ -0,0 +1,4 @@ +xA + {^s=YL՚ ( +ouj)  +Z7yv,ԴwVQ iGiҤDfەwo4ѤoLLȼ}4 h \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_61_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_61_0.dat new file mode 100644 index 0000000..93d2444 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_61_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_65_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_65_0.dat new file mode 100644 index 0000000..df29d7b Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_65_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_69_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_69_0.dat new file mode 100644 index 0000000..8a2cfbd --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_69_0.dat @@ -0,0 +1 @@ +xK =_+mBd|Q"s+1"),=Ea T"ŐnE-3 ,KYw=ZZT .,K1#֞!Ŋ+V嬪.2XbŊ+VX.kBzwձ̀gkYZ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_89_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_89_0.dat new file mode 100644 index 0000000..aaa4c52 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_89_0.dat @@ -0,0 +1 @@ +x1 ὧi9'Hl?L^"&M?bq?˸,9!z]VScƌ3_c!`n3f̘1č 3f̘1/f>.Uc˻; 2;Y+7 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_93_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_93_0.dat new file mode 100644 index 0000000..e218fa0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_0/mask_93_0.dat @@ -0,0 +1,3 @@ +xK + EyV,OmޠrPH0{2bc{tQ] +{Q{{弬֒ǎ;v_ڳ}L}l߱cǎ;v̑̑̑رcǎ.Legw3qeѾ@i \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_0/mask_97_0.dat b/src-backup/includes/phpqrcode/cache/mask_0/mask_97_0.dat new file mode 100644 index 0000000..74ac719 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_0/mask_97_0.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_101_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_101_1.dat new file mode 100644 index 0000000..ec939b5 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_101_1.dat @@ -0,0 +1,2 @@ +x1 + н\QEd  1N<#Ֆ-7u.lԦeiXXXXXRZVVeIo1,,,,,v%?gaaaaY K&K=/+ۍ˱ގ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_105_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_105_1.dat new file mode 100644 index 0000000..e1f5c99 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_105_1.dat @@ -0,0 +1 @@ +x1 Ӕ_Υb KB?"*#WʘtgӎJqUM9TLLvǤLLLLLLzgG01111yiߘ4m=՛n+2 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_109_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_109_1.dat new file mode 100644 index 0000000..7e0d6d1 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_109_1.dat @@ -0,0 +1 @@ +xֱ >ӘK}:!iY'*3]fsmb[JƶŖK9}cccccc'u.6Ʀs6666R[^g{/lٷ 7͂ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_113_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_113_1.dat new file mode 100644 index 0000000..1dd666d --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_113_1.dat @@ -0,0 +1 @@ +x1  -8fL(pBlDM9";-;?1p{\%-3:@ad4*Nadddddd########c]751xYu \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_117_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_117_1.dat new file mode 100644 index 0000000..8921f64 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_117_1.dat @@ -0,0 +1,2 @@ +xֻ >ӘK$^ 8YQSV'z8jzʇ^]סekXYYYYYYYjݵ# ++yeeeeeeee#WVVVVVVVV;"+yeeeeeeel'e;b&^9{/J$p \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_121_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_121_1.dat new file mode 100644 index 0000000..64bd8ba --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_121_1.dat @@ -0,0 +1,2 @@ +x1 + н\CPbїE$DdƩYtڅλ0$ήꝝga7yٯ痽Y??{{D \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_129_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_129_1.dat new file mode 100644 index 0000000..62cd1c9 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_129_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_133_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_133_1.dat new file mode 100644 index 0000000..18d68dc --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_133_1.dat @@ -0,0 +1 @@ +x1 Ӕ_΅hh|"zۉ-*dNHQĢR ,X`c9Y(na_` ,X,X,X` #:8  ,X`Bd¾` ,X|ϢY\X; 7-; ` \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_137_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_137_1.dat new file mode 100644 index 0000000..284d7be --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_137_1.dat @@ -0,0 +1,3 @@ +x1 +0 ӤKh]D,-t #ڌQ[T Ks7_?9|B&X^L0a„&3„M&L0a„ &2D4c0a„ &LȀЌe„ &L0abwȀf,&L0a„7&y2anoL<01O + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_141_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_141_1.dat new file mode 100644 index 0000000..83220dd --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_141_1.dat @@ -0,0 +1,2 @@ +x1 + >946)3$`s uʮ>Wd )g'M{3\d6ubذaÆ 6lؼn]Nذ9FްaÆ 6lذa3a#oذaÆ 6lذذ5e16lذaÆ ]Sbk6lذaÆ mͤ;CcfIdsG \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_145_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_145_1.dat new file mode 100644 index 0000000..6a9950f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_145_1.dat @@ -0,0 +1 @@ +x!0@k 4a)q2i.YCUO{35UZFn]fN>bdwtzJF}F1bĈ#F(F6r1bĈ#F1E1ilF1bĈ#FtF#F1bĈ#FtZ}##F1bĈleHGܣ@ٝ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_149_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_149_1.dat new file mode 100644 index 0000000..02a3cdc --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_149_1.dat @@ -0,0 +1 @@ +x1 Ӕ_΅qH_Xci#Gd̘Ք՛gLU^ݮVR>dKVXbŊ+VXeoXJ_bŊ+VXb;ݙ+}Ŋ+VXbŊ+VAVngŊ+VXbŊ}+ +VXbŊVj>hewf*`uTq \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_153_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_153_1.dat new file mode 100644 index 0000000..2abfca2 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_153_1.dat @@ -0,0 +1,2 @@ +x1 +0\9btEc'HH9efߞmffM#.̘1cƌ3f̘1cf73f̘g̘1cƌ3f̘1co2c]?3f̘1cƌ3f5Mf3f̘1cƌ3f̘17utf3f̘1cƌ3f̘=lj3>V \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_157_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_157_1.dat new file mode 100644 index 0000000..17344b8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_157_1.dat @@ -0,0 +1,2 @@ +x1 + >94Sd/51V)SkJv7eGcǎ;vرc]Zٱc'رcǎ;vر+رg;vرcǎ;}V`N+رcǎ;v:;v;vرcǎ;;}Vޱcǎ;vص'vz#;]klwoA` \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_161_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_161_1.dat new file mode 100644 index 0000000..669ade1 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_161_1.dat @@ -0,0 +1 @@ +x10_΅Xš yi~Qbkvp7'M u=]([ 2dȐ +\' 2 2dȐ!C 2s0/3d() 2dȐ!C 241dh 2dȐ!C 2dhcȐSL2eʔ)SL2M SLSL2eʔ)SL2M}LSSL2eʔ)SLeSy)SŔ)SL2eʔ)S;ٔ)S;)SL2eʔ)Sv()Sv()SL2eʔ)SLdT6}a*3mljmzC' \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_173_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_173_1.dat new file mode 100644 index 0000000..436918c --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_173_1.dat @@ -0,0 +1 @@ +x1 Ӕ_Υ''@y]X1?"g:1犝fn˶˻mm.?lٲe˖-F>glٲ2lٲe˖-[lٲeO`˖e˖-[lٲe˖-[l lٲlٲe˖-[lٲeVO`˖e˖-[lٲe˖-[z0}[z0y˖-[lٲe˖-[Ee[hOVWö=t*| \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_177_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_177_1.dat new file mode 100644 index 0000000..12e2e52 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_177_1.dat @@ -0,0 +1 @@ +x1 Ep0X,a#r}6}nj~\8ƌ3f̘1cƌ7{3f,y3f̘1cƌ3fX_`X&3f̘1cƌ3f̘M_1cy̘1cƌ3f̘1cƌ+3f,y3f̘1cƌ3fX_bX&3f̘1cƌ3fx2dX'x[cy| 3 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_21_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_21_1.dat new file mode 100644 index 0000000..f87e0a1 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_21_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_25_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_25_1.dat new file mode 100644 index 0000000..3a225e3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_25_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_29_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_29_1.dat new file mode 100644 index 0000000..0a1cb3b Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_29_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_33_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_33_1.dat new file mode 100644 index 0000000..318949d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_33_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_37_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_37_1.dat new file mode 100644 index 0000000..5bd9e3a Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_37_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_41_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_41_1.dat new file mode 100644 index 0000000..52e9e58 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_41_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_45_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_45_1.dat new file mode 100644 index 0000000..b35c567 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_45_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_49_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_49_1.dat new file mode 100644 index 0000000..d20d717 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_49_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_53_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_53_1.dat new file mode 100644 index 0000000..a676d7d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_53_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_57_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_57_1.dat new file mode 100644 index 0000000..896ed43 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_1/mask_57_1.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_61_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_61_1.dat new file mode 100644 index 0000000..4165a4b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_61_1.dat @@ -0,0 +1 @@ +x30CbpPi`@&H^nadQG{n_.4Iy킎`)-5*(of[sm}6YM ;;;;;G{zطz1vw}=wuL%?"=~ei \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_1/mask_97_1.dat b/src-backup/includes/phpqrcode/cache/mask_1/mask_97_1.dat new file mode 100644 index 0000000..24fa60f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_1/mask_97_1.dat @@ -0,0 +1,2 @@ +x1 +0н1\tncKD"H$DH$D"Q&WerH$D"*x[(?/'nd \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_117_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_117_2.dat new file mode 100644 index 0000000..b4dcce4 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_117_2.dat @@ -0,0 +1,2 @@ +x1 + >94!m dOs\0X,la5#E>Z[ַRT*JR?Q-*T*JR?UW*JRTݟ+JRԤ~m5;S&+ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_121_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_121_2.dat new file mode 100644 index 0000000..a2a0097 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_121_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_125_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_125_2.dat new file mode 100644 index 0000000..0ea40fd --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_125_2.dat @@ -0,0 +1 @@ +x! PӔ_@ U(kp@^Mڮ5-:VF_\t:NtyNqt:NtG;Nt:.8:NtzA}yNq;+n& \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_129_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_129_2.dat new file mode 100644 index 0000000..bf04839 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_129_2.dat @@ -0,0 +1,2 @@ +x1 +0н_KVڡ'.!w]A0X~  !࣠fK# xFy4 vey@^+  ~  L#veI \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_133_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_133_2.dat new file mode 100644 index 0000000..9e78b6d --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_133_2.dat @@ -0,0 +1,10 @@ +x1 + н&`LQ-g=Aqbʪl fƄȚ44& )OȚYF4444444444c4~9S:3ЌטpǮ> \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_145_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_145_2.dat new file mode 100644 index 0000000..9ff2bbf --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_145_2.dat @@ -0,0 +1,4 @@ +x1 + нr] +,tQ^&C~ +щj~mɾ.FgMDDDDDDDDDDDST׈DHdZL+ɴDDDDDDDDDDD2-'"""""""":BתEYDd \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_149_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_149_2.dat new file mode 100644 index 0000000..d52e048 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_149_2.dat @@ -0,0 +1 @@ +x;@/gcaGBXB'-ˆouէUQdRVOmT*ǫ;;j廝Ee2PQQQQQQQQQQQ TTTTTTTTTTTTr33R &Tskz_e2P=d \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_153_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_153_2.dat new file mode 100644 index 0000000..3b06041 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_153_2.dat @@ -0,0 +1,2 @@ +x1 +0 Ӥ8ZP!BZu賶"bu*)]MFFFFFFFFFFFF%= #ddddddddddddr ot2yFFFFFFFFFFFF& #k5L 2222222222(Y7"d@H \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_157_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_157_2.dat new file mode 100644 index 0000000..2baf535 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_157_2.dat @@ -0,0 +1,3 @@ +x1 +0>s6MqUH1X&U̘f/u-'.[KGGGGGGGGGGH|NG(ttttttttttNF;::::::::::}Nz$ +>n A#^AG(t =3{ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_161_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_161_2.dat new file mode 100644 index 0000000..d2df759 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_161_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_165_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_165_2.dat new file mode 100644 index 0000000..2e6cd7c --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_165_2.dat @@ -0,0 +1,2 @@ +x1 +0 Ӥ?BVUG%*+_fs MIIIIIIIII2d;l4()))))))))))eqJنIDIIIIIIIIIII)۠mPRRRRRRRRRRR6l JJJJJJJJJJJJن}RaQRRRRRRRRRRNeK?R퐔͔&W3U \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_169_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_169_2.dat new file mode 100644 index 0000000..4052062 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_169_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_173_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_173_2.dat new file mode 100644 index 0000000..0a30ba5 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_173_2.dat @@ -0,0 +1 @@ +x+@ Pift:>y &d U߬S[]5Z;a5V۞A[Z˴VՃI0ZZZZZZZZZZZZZZ=-Lhi`VFK?ݧhioJ0}o \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_177_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_177_2.dat new file mode 100644 index 0000000..d2c52f9 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_177_2.dat @@ -0,0 +1,2 @@ +x1 + E>Y4V$~ ,C&U;Ook5bϙGx9%&&&&&&&&&&&n$OL|v#&&&&&&&&&&&&&bbݍXw#&l7bbbbbbbbbbbbbbM"l7bbbbbbbbbbbbbbMa!&݈3)U*F> \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_45_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_45_2.dat new file mode 100644 index 0000000..ad44ff1 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_45_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_49_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_49_2.dat new file mode 100644 index 0000000..6e8edff Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_49_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_53_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_53_2.dat new file mode 100644 index 0000000..682cae2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_53_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_57_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_57_2.dat new file mode 100644 index 0000000..66a5c05 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_57_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_61_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_61_2.dat new file mode 100644 index 0000000..77d3815 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_61_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_65_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_65_2.dat new file mode 100644 index 0000000..caf184a Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_65_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_69_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_69_2.dat new file mode 100644 index 0000000..6a3801b Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_69_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_73_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_73_2.dat new file mode 100644 index 0000000..74945b7 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_2/mask_73_2.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_77_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_77_2.dat new file mode 100644 index 0000000..903cba4 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_77_2.dat @@ -0,0 +1 @@ +x1 н_CM>Gt ѫe+FWZEm&gއFѶhF+t/FYvFj[*7a \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_81_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_81_2.dat new file mode 100644 index 0000000..17a9ac2 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_81_2.dat @@ -0,0 +1,2 @@ +x1 +0н_KҩVi!O\"A]:xbW1uȦ&_T ΋6H$U^D~bׯb=gX \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_85_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_85_2.dat new file mode 100644 index 0000000..72c74ff --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_85_2.dat @@ -0,0 +1,2 @@ +x1 +0=1\B7O$A0$8Wwjguu槊RT*uS֧JRTJRRޢN浘V \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_2/mask_89_2.dat b/src-backup/includes/phpqrcode/cache/mask_2/mask_89_2.dat new file mode 100644 index 0000000..06c9a4f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_2/mask_89_2.dat @@ -0,0 +1 @@ +xٱ 0 >/&E*cQqŃ zf$rM)_%s_d3KO1^aL,$H"$KzRPt[I&X9$H"$I$ysI$DI$ɓI$I$Dɍ%es!=LAZ5'̓IVrn/2oƅ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_113_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_113_3.dat new file mode 100644 index 0000000..023b273 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_113_3.dat @@ -0,0 +1,2 @@ +xA +0 D}NrnDFj2KCt?WݲZi.qoP %Smj7ަ:*N:@:***fW9d2*j*}S@`*j৪6Jlѿ}}էTUa24hnt \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_117_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_117_3.dat new file mode 100644 index 0000000..79cc04d --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_117_3.dat @@ -0,0 +1,4 @@ +x1 +0 ]Q.xIB$?~!z#E)RHZ@bl-)ݿ<ߧ*OUR"5&5*ie J]+ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_145_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_145_3.dat new file mode 100644 index 0000000..338b7e7 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_145_3.dat @@ -0,0 +1,3 @@ +x +@|:^ Jy̡yMj-' +9VS֦K9e)PyUwe-m jԨQF5jԨRi٫F4_wk}0+jRBRF5jԨQeOMBJHjԨQF5jwP״˪IH I5jԨQFͳc w5jԨQF:zS*2UZ_C*e_OZ%dIȯb \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_149_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_149_3.dat new file mode 100644 index 0000000..30bc5fa --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_149_3.dat @@ -0,0 +1 @@ +xA0}Oܠ⦐H頯'Z2{oV|Ι%>yR{!8ÂI+JpI|#f5κ[P A $H Q})&X{ט+Wb`I)5%d \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_153_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_153_3.dat new file mode 100644 index 0000000..89cdec0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_153_3.dat @@ -0,0 +1,2 @@ +xA +0}Ns˹)7mJ,}8X=cW^GeN}o%uJV/{%O>}ӧO}K~O>}ӧO>Q=/ї>}ӧO>}u{ח>}ӧO>}u{蟪/%?}ӧO>}ׯ.N4჏VMmRt(1| \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_177_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_177_3.dat new file mode 100644 index 0000000..9586979 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_177_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_21_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_21_3.dat new file mode 100644 index 0000000..bcb4eec Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_21_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_25_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_25_3.dat new file mode 100644 index 0000000..0ffc375 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_25_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_29_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_29_3.dat new file mode 100644 index 0000000..6150ac1 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_29_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_33_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_33_3.dat new file mode 100644 index 0000000..6053b5e Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_33_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_37_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_37_3.dat new file mode 100644 index 0000000..5dea5b9 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_37_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_41_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_41_3.dat new file mode 100644 index 0000000..ca9ddc2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_41_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_45_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_45_3.dat new file mode 100644 index 0000000..3daad97 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_45_3.dat @@ -0,0 +1,2 @@ +xK + DsFJ(&)0dЇFg![8=&iaD)d8&Aլa 1'II׳79 ex߾ I&֝CuJy \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_49_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_49_3.dat new file mode 100644 index 0000000..7f6508d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_49_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_53_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_53_3.dat new file mode 100644 index 0000000..8800bea --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_53_3.dat @@ -0,0 +1,2 @@ +xK +0Ds ! -(.Bp&|"-t&`qQ-"9_+)Be/H8D%a~}spKFN=,;;a^t4\FSN \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_57_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_57_3.dat new file mode 100644 index 0000000..4e1e5da Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_57_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_61_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_61_3.dat new file mode 100644 index 0000000..bf1a3cc --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_61_3.dat @@ -0,0 +1,2 @@ +xA +0fz4-%*dp!yZܫu(~=&ۓ)R2"/"<9FΊ=rb"/rw"2B#3-0-KW \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_65_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_65_3.dat new file mode 100644 index 0000000..8589208 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_65_3.dat @@ -0,0 +1,2 @@ +xQ + D4\?R ,!O-Nv1:cZu "UMÕF ~jK-la[^q^Q\=o-laZpUB @IKJzɢ|1Í  \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_69_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_69_3.dat new file mode 100644 index 0000000..55318a8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_69_3.dat @@ -0,0 +1,2 @@ +x +0 {&2'd l=,Fy;$쇤WE-R:%T,O2g"",Ȣ/DyĈɧ{O䮳",:NvEWN#(&,,]x؅ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_73_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_73_3.dat new file mode 100644 index 0000000..15be77f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_73_3.dat @@ -0,0 +1,2 @@ +xQ +0 C{g;JJ?dԬK=RasJhTJ6exka\$nIE,-/XB*х=wee4t̒tLщtt߫b gFf qoddn-? \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_77_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_77_3.dat new file mode 100644 index 0000000..ec78280 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_77_3.dat @@ -0,0 +1,2 @@ +xA +0 &BiRaK"t`I@|fXyilE:Sza18GifK*?:YC1쌞졘(ቷJ*jl*TRIKR^ؙks)c)c)JZa \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_81_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_81_3.dat new file mode 100644 index 0000000..47bc0f7 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_81_3.dat @@ -0,0 +1,2 @@ +x1 + F=\,JGAġhj>#3X:kԹ\FM Jhu3>TZ{PSgP'kVjժU_ۯUV=P oO:Wҝj[Wxm 5 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_85_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_85_3.dat new file mode 100644 index 0000000..02c4f8c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_85_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_89_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_89_3.dat new file mode 100644 index 0000000..2b4cb59 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_89_3.dat @@ -0,0 +1,2 @@ +x1 ὧ) *.@U |eŵ6ۢw5*) oiK4nk>1}d>@ 4XYCo ۡ1<AhFt + 4@51Wr>7G}}x7|NgN \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_93_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_93_3.dat new file mode 100644 index 0000000..b4cc8a9 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_3/mask_93_3.dat @@ -0,0 +1,2 @@ +xA +0 D}NrnJɪQ~B06na<<ׇe6MRCP L̓i9M 2 LkŮdDv*"aXjBdAddZTdAdqY0exqeN&WVQvc \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_3/mask_97_3.dat b/src-backup/includes/phpqrcode/cache/mask_3/mask_97_3.dat new file mode 100644 index 0000000..7adc9eb Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_3/mask_97_3.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_101_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_101_4.dat new file mode 100644 index 0000000..1c97dc0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_101_4.dat @@ -0,0 +1,2 @@ +xA Fs^1bИ]4m+8+Ve^HR]\c +oWN#X+l HEcp \^.9qW9":.BB \0aPǨcp \ONqjpG}}$.˅ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_105_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_105_4.dat new file mode 100644 index 0000000..0211cdb --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_105_4.dat @@ -0,0 +1,2 @@ +xK +0 D=Mr˹A TeEFL2 #鹢_I!딤Ѻ-իkmO]sS T6*'8 N$'NZ^}rU*G9r|c[cN[_=׫5^J 1*qv \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_117_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_117_4.dat new file mode 100644 index 0000000..3867259 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_117_4.dat @@ -0,0 +1,2 @@ +x + н_s]4Dgn2Jj}ҾRsSWGRɧ)5Em#ܯk_"z3\rʕ+r Lk|/{;'/#\p\p># \p\p#>qp\p.$Iq dGR_4  \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_137_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_137_4.dat new file mode 100644 index 0000000..0c09c48 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_137_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_141_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_141_4.dat new file mode 100644 index 0000000..62b03f2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_141_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_145_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_145_4.dat new file mode 100644 index 0000000..33fb211 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_145_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_149_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_149_4.dat new file mode 100644 index 0000000..de99310 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_149_4.dat @@ -0,0 +1,2 @@ +x +!н_sm +XӋ9=.=Zka]ޒ> Kjo |SSWKZm׌j\Ъ2 W\qW\q"~ jvtv_\qW\qW\q%g3 }+++ r9ArW\qW\qŕA g3WA W\qW\qW]V~v{D3Ȝ!\W^Tڍ[S7vۜgq? +{peo383838{YXz,_OYfe3s38383\C!Ms38383r \C?37938383\C!07M8383q,mMrskWv3~W WB \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_157_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_157_4.dat new file mode 100644 index 0000000..ad5fcf6 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_157_4.dat @@ -0,0 +1 @@ +x10ޯs4"FP=iRX¢X0멪u 4ftl}m➭S|юS P5<]rwqwq^QN6ÏZsߙ,wqwqǝ>Μ5g;;Y}Vgw,wqwqw>9wqwq>3gY;[ww?P3Ƙggt퐮;].3w4A \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_161_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_161_4.dat new file mode 100644 index 0000000..7604c45 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_161_4.dat @@ -0,0 +1 @@ +xA@ fs!AL_|,4l)iml׉0' +E ]N\x#2/_{7g9쏼ٷ}2r!?}-#Te9C9C9~6Sʇ겺!r!r!ۘse9C9C94_Ɯ|.r!r!s/s0 2r!r8}DwrDXΡ|x|!2 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_165_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_165_4.dat new file mode 100644 index 0000000..d83d631 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_165_4.dat @@ -0,0 +1,3 @@ +xA +1 }Or."*?fPLHIkΫZQ8 +Gyqk-n5+?|֎kKnEŹK.K.?2.|EJ{2<:.Ku\K.K.ǝmu)_8\r%\r%\Џ;'2!_8\r%\r%\Џ;'2!_\r%\r%\rinC?nn9 RK.K.;.HqY'ݽNF?K㕢,R| My*3 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_169_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_169_4.dat new file mode 100644 index 0000000..4aac95c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_169_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_173_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_173_4.dat new file mode 100644 index 0000000..9df4d86 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_173_4.dat @@ -0,0 +1,2 @@ +xK +1}Nrna ~ZY!Jt^5(/jkz[pj_?~v:|jwՖ_mXzo6?naCe \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_81_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_81_4.dat new file mode 100644 index 0000000..dd65216 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_81_4.dat @@ -0,0 +1,3 @@ +xA +0 yMyXE m7"892ѸQ1ݳ+xx;t35DIY1x\:u}e/ #Th< +UBz<5G<5{G<5<饫>]Urxu \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_85_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_85_4.dat new file mode 100644 index 0000000..c8d5123 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_85_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_89_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_89_4.dat new file mode 100644 index 0000000..5b9bd7e --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_89_4.dat @@ -0,0 +1,2 @@ +x1 +0 ὧI9%  Vڀfr0}z=#9ҕ:~s1BՁg&4pgq.p.&gT05rgsgqrg捯u38k.Egmb*&7? : \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_93_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_93_4.dat new file mode 100644 index 0000000..be7f5e5 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_4/mask_93_4.dat @@ -0,0 +1,2 @@ +xK + ὧIn$}PŌB]N@%sfkҫ}CzoA}aʽ2|~D&l=Ywq}q\EYjK_ywqwz$==;_݋>+pH9Di \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_4/mask_97_4.dat b/src-backup/includes/phpqrcode/cache/mask_4/mask_97_4.dat new file mode 100644 index 0000000..5d848ca Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_4/mask_97_4.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_101_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_101_5.dat new file mode 100644 index 0000000..c21869e --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_101_5.dat @@ -0,0 +1,2 @@ +x + E+%=M3Cbv ѬNkûgqkqq{%Oo,iKee3[|iVh]` ` 0ʕz˴T0Gu/q8F13:W>#ȕ0c0Q8E=F#+a X͞+cV%9W>Q]TkY-gLqD艋 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_105_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_105_5.dat new file mode 100644 index 0000000..bc8798c Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_105_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_109_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_109_5.dat new file mode 100644 index 0000000..25a3944 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_109_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_113_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_113_5.dat new file mode 100644 index 0000000..25f42b8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_113_5.dat @@ -0,0 +1,9 @@ +x +0D^6I63[[EDqc+jy81\c +7c?u}DK4},kkg--3[UƂyUXUXSV:ϫ՝,|кS⫰ + + +Vɫ*X[* + + +zU*NV*JUXUXSXijTi4fZkU^_~Ux }ծZ/r \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_117_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_117_5.dat new file mode 100644 index 0000000..f236940 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_117_5.dat @@ -0,0 +1 @@ +x D|Mn/*{M+pI_&m-ѾC32u?o-kgB7wc=U%yoRhӯșDo:ֶyRJkQ^aaaqOgiJ ;qOg)ӊ0 0 0 [vö>=>0 0 0 Ofz3=>0 0 0.3Z$׷8\pw4:Zp:qX 7 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_121_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_121_5.dat new file mode 100644 index 0000000..9bb5c41 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_121_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_125_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_125_5.dat new file mode 100644 index 0000000..2161c50 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_125_5.dat @@ -0,0 +1,2 @@ +xA + E&fc;S$?؏Q4YahûyJ}9g==li.;nh_wz.qCWȧy uPk;<<<|*q, mkWqNl% yyyy^2䰅sX|aaaa3ϙ9lH<<<<̿웁[n`Tq8^vy \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_129_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_129_5.dat new file mode 100644 index 0000000..f0c1d65 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_129_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_133_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_133_5.dat new file mode 100644 index 0000000..46be8b0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_133_5.dat @@ -0,0 +1,2 @@ +xA +0 DѽOcr]4%1mCTxΜ[Dv={FEϏq?ݿ9keѭ}'2^c4G:3=JK-F0`#Hw'#<{~Z4 :BG舻F0`G~:`#?#tw-`#?##t#F0r}Q}eR;M/k1mX=hsH"k M:3qOW}9ԖIH1G;- sڶ?[%M + v#;zg^3d}69Ψޙ@7҄#gv`;׳ީ\$wlv`v;ލ}7wߑa;vkA#gv`=N2wxgWӤ@n?c}SQ:Zd?+9vz)P \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_141_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_141_5.dat new file mode 100644 index 0000000..60c1a8e Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_141_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_145_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_145_5.dat new file mode 100644 index 0000000..9303c07 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_145_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_149_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_149_5.dat new file mode 100644 index 0000000..4256cef --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_149_5.dat @@ -0,0 +1,3 @@ +x[ +0&c}-s+'^;Ax=Q_gUݏﵪxGTȺV¹UUE_IǴ;T1̠ +]W 2 2 |o5uꆬuI:(WKU躒rPAdAdA; vo_zNO{2rPA9 2 29}^O挞rwQdAdAnMA9(dAdA^W Z.+G^K`׵}`_Fk \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_153_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_153_5.dat new file mode 100644 index 0000000..deea09d --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_153_5.dat @@ -0,0 +1,2 @@ +x +@wfЬ`D"Ie<:au,7Of۳uP6~szs,jլcVZvߨm s^uHYu&l&l&_9 ;]^jsO;ܔrSn&l&l9yכzA rSnM6dM6dM6ރ@/$7ܔl&l&lzŽzACrSnM6dM6dOl7ᰚUuN֛FcPPS,l;HO \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_157_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_157_5.dat new file mode 100644 index 0000000..176e2a6 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_157_5.dat @@ -0,0 +1 @@ +x10Dާri( r* \~>C*vs]Ŝ_{W!zﶬ/)˙v V6V޻,f1Yb n^o>\O],,b,f1YyVgYYYb,f1+ʳ<˳<˳1YbŬ<+ʳ,,b,f1YyVgYYYb,fukys77}vmb=wsw)tW: \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_161_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_161_5.dat new file mode 100644 index 0000000..70d5fb0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_161_5.dat @@ -0,0 +1,2 @@ +xI +@нDp@ o|m rHk㨤~co^Jzװ#5l¦S_92 [}ZÊ=T2ƀP2[cV衆CYf'-X9>v~usK5`e,2,2,2-///o_q}K\reYfeYf峖o+/,\feYfeYfٳexB.e2,2,̲g+l\r16,2,>ϰ=te&_4=tU}/>>>Or5/u>/g}g}gOsvO}/g}g}ٷGo-w{r_{g}g}g_n=n]4Nkβ_M8m?SF< \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_173_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_173_5.dat new file mode 100644 index 0000000..f9a6741 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_173_5.dat @@ -0,0 +1,4 @@ +x[ +0&G1gD)[CzeDѷц=RN6FJm JqP}x s_}GFy; +[;]ek[QbTmy&0 L`̄Y?رw؛ fcVN9&0 L`ׄZ}0=F=F9ANL`&0 L`BzYfI=F9AN&0 L`&0 fIsr ' L`&0 L`<i͒"9AN&0 L`VaBX",Um> +=wZgBΜP !8 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_177_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_177_5.dat new file mode 100644 index 0000000..b07c636 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_177_5.dat @@ -0,0 +1,11 @@ +xъ0~ܾح uO,"% :$Xui=ѶՃgƸ?Ώq.So~z׉W:=h1cq]Ƕi!r8Ɓ`+X +V jj;8ƁX+ +oV`+X +V?[1^h-ֳ5Z;rmS+ +oV`+X +V;Z,YMB+ +V`+X +VZeڦ}r\!W`+X +V`+3Km>SB+ +V`+X +Vc㊛{g;^Qq5ZUݮQL0+*&YDq*6 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_21_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_21_5.dat new file mode 100644 index 0000000..04f97ea Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_21_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_25_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_25_5.dat new file mode 100644 index 0000000..c20b59b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_25_5.dat @@ -0,0 +1,2 @@ +xڝa +@!4 ޳ʢ ?,""j?n=GZy:DR \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_33_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_33_5.dat new file mode 100644 index 0000000..726d7fd Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_33_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_37_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_37_5.dat new file mode 100644 index 0000000..6d32ca6 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_37_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_41_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_41_5.dat new file mode 100644 index 0000000..e07c617 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_41_5.dat @@ -0,0 +1,2 @@ +xTA + 5?7XMtxҴx ?@7@~"N$Sɰ{+CA'r\Pp<ޏ- ͺ:S3sԉۻީz#qw > \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_45_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_45_5.dat new file mode 100644 index 0000000..5168a17 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_45_5.dat @@ -0,0 +1 @@ +xUA 5?U:N&Z":;4P1=bNvSGM1˛n'(κ J{Eѵs] ,sq \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_49_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_49_5.dat new file mode 100644 index 0000000..9f3f3cd Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_49_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_53_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_53_5.dat new file mode 100644 index 0000000..449807b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_53_5.dat @@ -0,0 +1 @@ +xVA " zYf5ƐJC A;l\,dR. \(e_ еaNi5\żaLP(;2שjN6O u+l{y6od^ C[%  \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_57_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_57_5.dat new file mode 100644 index 0000000..c7dd81f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_57_5.dat @@ -0,0 +1,2 @@ +xVA + 5?NlZHAbBZ0a Md`1z'"<Ր19nvͨ. )bݻ~;9Z#tB~ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_65_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_65_5.dat new file mode 100644 index 0000000..ecd9380 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_65_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_69_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_69_5.dat new file mode 100644 index 0000000..ead4edc Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_69_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_73_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_73_5.dat new file mode 100644 index 0000000..0000117 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_73_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_77_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_77_5.dat new file mode 100644 index 0000000..1652cdc --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_77_5.dat @@ -0,0 +1 @@ +xQ Cw#&C`T6ƹB(9 'ֆڢzk"hv.` cXB5[(F>71/34Ϊz^'[FyglgM>OTL4ϔ{&3Wy*ʧb*`<3;Vo0/s6n0ya[mcE \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_81_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_81_5.dat new file mode 100644 index 0000000..71215e9 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_81_5.dat @@ -0,0 +1,3 @@ +x + C~M?tzU4" }tMX2|.ɋ˙F\~m4Xu +ٔ, w:EƄ>X̯=_]g>>zמ/)5ךkkkZsXXY{ܮ}~mt:S#&;U#) \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_85_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_85_5.dat new file mode 100644 index 0000000..09cf0e2 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_5/mask_85_5.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_89_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_89_5.dat new file mode 100644 index 0000000..5fff530 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_89_5.dat @@ -0,0 +1,2 @@ +x + 45enpQ Gcfl^^;;b5;`kU͹߮j`NsO=\[a6~nLD? !6uF%w*Ȭkf77SĆbÆXodw_—mbClNۙ ck&YVoܡ׷BעبAl6 Jjx \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_5/mask_93_5.dat b/src-backup/includes/phpqrcode/cache/mask_5/mask_93_5.dat new file mode 100644 index 0000000..ec4240b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_5/mask_93_5.dat @@ -0,0 +1,2 @@ +xK +0 D>&&  fP^8BY5s(imҮ=f3/wۧEyYQwf[} [90303ef̙3'3=,ͼwxDַ.,;s%g,,,=Rὓ7uKKTD<(n lYhV۹sޕyPEtyY]ns ;ss,!LkԅcbL12cX91Z#XEn#;svT~L~LR11vs.1111J1&؍Ń111J1&ƞg KLƪjlk{gڞ5K1/ǐ~,ac$ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_105_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_105_6.dat new file mode 100644 index 0000000..a58fec7 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_105_6.dat @@ -0,0 +1,3 @@ +xQ +@ DskBZ#o)Sd}Gܷl쯯^)G]S4S?#BZ:+{sHKNiI!me1 +RWe9!``Uyˀu:檞U=w-oԺwB}cMK蹰{{=y蹰{{=y蹰{wScaoi'fyO=CyO=Cy[{S޻=;|v4}ϯ20 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_109_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_109_6.dat new file mode 100644 index 0000000..be7b474 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_109_6.dat @@ -0,0 +1 @@ +xA0 ~ρDBHCHV20nuol쯯˻=ۢs9[l'?7R" &2:7QqX_n ]$՚EIY*Lq0 0 0{LJз(s\ɳwX-7^ItIII$~?N0 0 0O'Itg7L$L-Iuzrfr M^'}(O~R]1YLĞu9Qӕ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_113_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_113_6.dat new file mode 100644 index 0000000..397f527 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_113_6.dat @@ -0,0 +1,3 @@ +x E5NՉbF6on,m>gS9RWcǕ9&%1_cx= GR^w-z?dzv=,}ԥ?ǹژ:9m==@U䲉UXUXVe~by4Wi:e=ɼÆ$<>Ov'Cytaaaa~|'9liΣ<<<<Iæ<:<<<ٕWDzy:.z= ݓʯ sVöE=ll_k0_#vίmj \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_129_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_129_6.dat new file mode 100644 index 0000000..b4695c3 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_129_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_133_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_133_6.dat new file mode 100644 index 0000000..40911dc Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_133_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_137_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_137_6.dat new file mode 100644 index 0000000..43ccb68 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_137_6.dat @@ -0,0 +1,2 @@ +x E5?e^4fHp[1-e)UQV]UWN5o*8|۩W6bk?{f|>s֪r666rҟ=vڲWy -' +Ο;q tQE>U϶f곭xN]Tc(s❮7tAw`v`v`v`kvwfwt;];;;;;!ޙ;ao];l;;;÷| ʷ(3}l.?"މr};\}S-Aw<9;EV'ם \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_141_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_141_6.dat new file mode 100644 index 0000000..0340409 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_141_6.dat @@ -0,0 +1,10 @@ +xa F4/c]زȐ[=[E럓sm,fn/|kj\j?g[q(NOZc5SGGP[oMVָfvL<WóCaz6U~һ{`nݻdvVy~rZ"qk{>g$XKU}m\bjaGx,f1Yb]z̞^.5[?嬜r,f1YY>grVb,f1Y>g,rVmYb,f,|VY9Yb,f,|VY9+g1Ybً ̦M7>2{9z϶hm3l|9xټ#f#x6 -v%N' \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_161_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_161_6.dat new file mode 100644 index 0000000..ecec68b Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_161_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_165_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_165_6.dat new file mode 100644 index 0000000..d641dfa Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_165_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_169_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_169_6.dat new file mode 100644 index 0000000..ae68972 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_169_6.dat @@ -0,0 +1 @@ +xJ0i9[Jɘk{1b!gnhHkS뉭-V?KIׁ1큏1ƣݎ/`/z)*=3ڏg6^k65CY>㵾+'{է_Vˊx-J<ӛܗr_>>i;rO}/g}g}ٿ}}xO}/g}g}ٷGo/{{r_>>o/z^#}g}ٿd'ʳ|QRNS3YڳZ'msEǷj5 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_173_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_173_6.dat new file mode 100644 index 0000000..95fa97c --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_173_6.dat @@ -0,0 +1 @@ +xa09MrM S*:a_-5hh_)uZ֭[loےsmKN{H?x`l#f9>ڟ[eЄώߓ ?^m*/Kmhy%v-nKlkKL`&& g5(gwxYܞa¬pVcZ[#O=SN9&0 L`DŽ 'tjj]QN9&0 L`sYRc@QN9 L`&0 L`"YRc\ ' r&0 L`EH9AN&0 L`& 7p6`|hms R5Ƙȉ k\X/ )g9 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_177_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_177_6.dat new file mode 100644 index 0000000..e9f0476 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_177_6.dat @@ -0,0 +1,14 @@ +xn {ڤ*4v۴u1{f{_,,K9o 4ǵ7lniJiggir<-MG + + + +xuV+zRCr9+Gq6QWb"Qe"WL+ + XXXXX/|~j,nmuMۤ+ + XXXXXYa,X;M+ + XXXXXe)oӘf|5H늚7/D \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_21_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_21_6.dat new file mode 100644 index 0000000..6bd505b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_21_6.dat @@ -0,0 +1 @@ +xڝQ C9M{i]X1- C!D7 W ٜ&rD)~]<M 3(>{A aS \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_25_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_25_6.dat new file mode 100644 index 0000000..d45083a --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_25_6.dat @@ -0,0 +1 @@ +xڝQA 52)e+(XmZt*(ڹ;tJ<峂_ڤ3oڴ"̢azh}&qvSG֙,-J4}oS[}w \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_29_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_29_6.dat new file mode 100644 index 0000000..0408e22 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_29_6.dat @@ -0,0 +1,3 @@ +xRA +0 XcL(4EԈB +8Cܾ޳nM+lǝՆO1]&ڍ4UD-6-$:6dZ?ylf? 8?߲_ݏ`8G1`B`;+}&s]<iK'l'9%.7 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_65_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_65_6.dat new file mode 100644 index 0000000..550fc8f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_65_6.dat @@ -0,0 +1 @@ +xWQ i{KNLk?e$Qik41{`+!ڮM ? 1b8 .^wsnFj5EaQX|=w@2v<ŋŞ|4w\UXBQz+TTcBz/48,5`ȱ OV$ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_69_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_69_6.dat new file mode 100644 index 0000000..a3e4fa0 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_69_6.dat @@ -0,0 +1 @@ +xK @dTh hLSSEq eY@<+*|窮 %>z*7e6QS`.>sE '%@[6@P0h aFxtpl2 Q-g1Nfeo^0FdT>N_OwG3ug {3<[Ժ b?'6^ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_73_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_73_6.dat new file mode 100644 index 0000000..ab71b70 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_73_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_77_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_77_6.dat new file mode 100644 index 0000000..ad5a660 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_77_6.dat @@ -0,0 +1 @@ +x E۲iVa.FpSTY4q~z=:͒ 6m8:#0PضiDy:2Š'Zs&}滜\r0\ŚXw;iPȔL)Seԕ{hDu9LbJSS))gZ{e)qJdLw+#3-V0շljڠS-S 9=ݯ5PPq1M?g \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_81_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_81_6.dat new file mode 100644 index 0000000..28a6d07 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_81_6.dat @@ -0,0 +1,3 @@ +xQ0D9 rRLvk`0 ;i6\|_cc1huio#2}x*.Yt& +ְq/K;3ve̢ȊAH?`]5Kw!}{Zû߲W +yⷾ^_ykk^Kתb-bYSڸ'֜Nu#MfHSQ?|]IAiMyyuW \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_85_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_85_6.dat new file mode 100644 index 0000000..d5403e4 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_85_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_89_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_89_6.dat new file mode 100644 index 0000000..eeeb5d1 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_89_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_93_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_93_6.dat new file mode 100644 index 0000000..6ff38db Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_6/mask_93_6.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_6/mask_97_6.dat b/src-backup/includes/phpqrcode/cache/mask_6/mask_97_6.dat new file mode 100644 index 0000000..3a2072e --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_6/mask_97_6.dat @@ -0,0 +1,2 @@ +xa0sdFx[=4Hoj34&s}* a Vc&35arW^aLClzq,1x SQN]/Giu`&w%,%DY"Kt+HE'|R2(v1vqiqd,%D~%ػJj}ͺĺgY"Kd,+K +]Wt+sF/)].zN'`>1='#`+bl]Z \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_101_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_101_7.dat new file mode 100644 index 0000000..1f6bc51 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_101_7.dat @@ -0,0 +1 @@ +xQ C}rm`fjT#54'tfaЇo$cmOJ23c<6Xn0F ) \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_105_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_105_7.dat new file mode 100644 index 0000000..6b0cacf --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_105_7.dat @@ -0,0 +1,2 @@ +xA +0EFaMҙNPx)pQ_~|ñ(bF$.aoWGNPUǖM%{oHQUlִL^>+m#{{eo&Y2soM)gncO9sZ3wo+{=f.zޣ{{=zGcskCQϞp^&{^NʷU e5}EwGn+o \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_109_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_109_7.dat new file mode 100644 index 0000000..9875cbe --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_109_7.dat @@ -0,0 +1,2 @@ +xA +0 D9Mr}* _x-d:"NJ-k"⨚d{ջגɬ|'rQ5+ s)c7-1nn햺qɔJtg^ʉw̘Ň-?*&Mm@ee5^ +c + +,b\13j4TZfŢo* + + +:Ut* + + +Xů0"%6ed 8rS NsUnk5XejުuVXg,l`u!hXZ\VlM|[ͬ0 0 0 #hF'c]i>Hataaa~<ÆzyqkO0 0 0 㪞Faaa)2˰fÒ%z8tO=3=3:cw +V$ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_121_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_121_7.dat new file mode 100644 index 0000000..d5d577f --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_121_7.dat @@ -0,0 +1,2 @@ +x[ + Edi;^az,#6ƞ^rh&^amY9_غ5Cr6t^^WlEز~ɿ|MmmS}( ۰ ۰ ۰}mQ]ZVq]vѲ"M1fG, qBmtaaazeF3cxIDmtaaamný$n۰ ۰ ۰ ۏa[}`[yޖ޻)n<4K/Oslnlm/G \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_125_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_125_7.dat new file mode 100644 index 0000000..f9ec088 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_7/mask_125_7.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_129_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_129_7.dat new file mode 100644 index 0000000..9bf51d5 Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_7/mask_129_7.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_133_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_133_7.dat new file mode 100644 index 0000000..b643ffe Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_7/mask_133_7.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_137_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_137_7.dat new file mode 100644 index 0000000..11d212b --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_137_7.dat @@ -0,0 +1,5 @@ +x + F4/ c_ǂ+{SK<o[l +Ο +07։Vl;b7fMS;1LCvR|KMH +#Н(Sqd \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_141_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_141_7.dat new file mode 100644 index 0000000..98dffab --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_141_7.dat @@ -0,0 +1 @@ +xA E= rITY@Ä0!|1tbG0ԗѤs2Z/oa\qzOnҋMntX"KmeM}CpPL^S0S0S0SL )ǔژY߾%b,Sl?zC)tLLLLI2zRXh@)tLLLLI1zbϷB)~0S0S0S07)|B)))3ՖL% tfwM*:~hZsnc$1UTtJg8OYE \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_145_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_145_7.dat new file mode 100644 index 0000000..4aa2bac --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_145_7.dat @@ -0,0 +1,2 @@ +x + E5?W6Z-^2qbGX6(Ɖu"LbbGuμGk:HwA[jmHݞ3OkQ{l|TEm JfL?2"&)kRfc̉F,z=5X5X5X7F\pUs#5X5X5XFdYk!a ` ` `o8ct ]CC gM5[N%khZp?Iܣϲ^n$Y7AZP[ fȓ0 \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_149_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_149_7.dat new file mode 100644 index 0000000..809f005 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_149_7.dat @@ -0,0 +1 @@ +xn {? uچ2G$ncFKb3֪tPc ̥7[?9:['9'*Ӗ Gah_/z+6XB>2qYJ0黏Bfa 1 9c7G Ol,^꽓3A:H  1A b0X4%٫#d>&C  1A b+g嬜,f1Yb|Y>+g嬜,f1Ylio.\Ɲo=gϙ-yk_TA \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_161_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_161_7.dat new file mode 100644 index 0000000..35ba8ff --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_161_7.dat @@ -0,0 +1 @@ +xю y/皨E)Ʈ1~493,˵+ZT=ZeC.~iߏ&>,6e~,lW] 2\;׵2j"e,rXݵV(c쵵ZӖ18ީ/,'t.ee,cX2߱,_|yt|]t.cX2e,cy/ɗys.eLe,cX2lo|Z{+2]bl,cX2e{+֊[A2]X2e,c9CX;QIQH8R҈G"z,&;'o97%P8%6oǽ;]NWn[f7v \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_29_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_29_7.dat new file mode 100644 index 0000000..e3d7391 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_29_7.dat @@ -0,0 +1,2 @@ +xR9 QpX$lŲf!I2pgSMZj"te0#ԛ`_1-cha~/Eh4"~ \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_37_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_37_7.dat new file mode 100644 index 0000000..87d9a1a Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_7/mask_37_7.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_41_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_41_7.dat new file mode 100644 index 0000000..8acec04 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_41_7.dat @@ -0,0 +1 @@ +xTA 5[fDY(O^bR3/~t/L"7SQQ5j\Sib#Նȏ+ǣw#zx?㽧A-wu曑Y7$b.%A;wRoxG}? \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_45_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_45_7.dat new file mode 100644 index 0000000..dbba31d Binary files /dev/null and b/src-backup/includes/phpqrcode/cache/mask_7/mask_45_7.dat differ diff --git a/src-backup/includes/phpqrcode/cache/mask_7/mask_49_7.dat b/src-backup/includes/phpqrcode/cache/mask_7/mask_49_7.dat new file mode 100644 index 0000000..be5dce8 --- /dev/null +++ b/src-backup/includes/phpqrcode/cache/mask_7/mask_49_7.dat @@ -0,0 +1 @@ +xV0khC-X.ukv o40T%96U5*sI{`_>S?}(:yTl{G&E\6}"AX XϬback'); + + // user data + $filename = $PNG_TEMP_DIR.'test'.md5($_REQUEST['data'].'|'.$errorCorrectionLevel.'|'.$matrixPointSize).'.png'; + QRcode::png($_REQUEST['data'], $filename, $errorCorrectionLevel, $matrixPointSize, 2); + + } else { + + //default data + echo 'You can provide data in GET parameter: like that
'; + QRcode::png('PHP QR Code :)', $filename, $errorCorrectionLevel, $matrixPointSize, 2); + + } + + //display generated file + echo '
'; + + //config form + echo '
+ Data:   + ECC:   + Size:   +

'; + + // benchmark + QRtools::timeBenchmark(); + + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/phpqrcode.php b/src-backup/includes/phpqrcode/phpqrcode.php new file mode 100644 index 0000000..80adb9d --- /dev/null +++ b/src-backup/includes/phpqrcode/phpqrcode.php @@ -0,0 +1,3312 @@ + + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + + +/* + * Version: 1.1.4 + * Build: 2010100721 + */ + + + +//---- qrconst.php ----------------------------- + + + + + +/* + * PHP QR Code encoder + * + * Common constants + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + // Encoding modes + + define('QR_MODE_NUL', -1); + define('QR_MODE_NUM', 0); + define('QR_MODE_AN', 1); + define('QR_MODE_8', 2); + define('QR_MODE_KANJI', 3); + define('QR_MODE_STRUCTURE', 4); + + // Levels of error correction. + + define('QR_ECLEVEL_L', 0); + define('QR_ECLEVEL_M', 1); + define('QR_ECLEVEL_Q', 2); + define('QR_ECLEVEL_H', 3); + + // Supported output formats + + define('QR_FORMAT_TEXT', 0); + define('QR_FORMAT_PNG', 1); + + class qrstr { + public static function set(&$srctab, $x, $y, $repl, $replLen = false) { + $srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false)?$replLen:strlen($repl)); + } + } + + + +//---- merged_config.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Config file, tuned-up for merged verion + */ + + define('QR_CACHEABLE', false); // use cache - more disk reads but less CPU power, masks and format templates are stored there + define('QR_CACHE_DIR', false); // used when QR_CACHEABLE === true + define('QR_LOG_DIR', false); // default error logs dir + + define('QR_FIND_BEST_MASK', true); // if true, estimates best mask (spec. default, but extremally slow; set to false to significant performance boost but (propably) worst quality code + define('QR_FIND_FROM_RANDOM', 2); // if false, checks all masks available, otherwise value tells count of masks need to be checked, mask id are got randomly + define('QR_DEFAULT_MASK', 2); // when QR_FIND_BEST_MASK === false + + define('QR_PNG_MAXIMUM_SIZE', 1024); // maximum allowed png image width (in pixels), tune to make sure GD and PHP can handle such big images + + + + +//---- qrtools.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Toolset, handy and debug utilites. + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRtools { + + //---------------------------------------------------------------------- + public static function binarize($frame) + { + $len = count($frame); + foreach ($frame as &$frameLine) { + + for($i=0; $i<$len; $i++) { + $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0'; + } + } + + return $frame; + } + + //---------------------------------------------------------------------- + public static function tcpdfBarcodeArray($code, $mode = 'QR,L', $tcPdfVersion = '4.5.037') + { + $barcode_array = array(); + + if (!is_array($mode)) + $mode = explode(',', $mode); + + $eccLevel = 'L'; + + if (count($mode) > 1) { + $eccLevel = $mode[1]; + } + + $qrTab = QRcode::text($code, false, $eccLevel); + $size = count($qrTab); + + $barcode_array['num_rows'] = $size; + $barcode_array['num_cols'] = $size; + $barcode_array['bcode'] = array(); + + foreach ($qrTab as $line) { + $arrAdd = array(); + foreach(str_split($line) as $char) + $arrAdd[] = ($char=='1')?1:0; + $barcode_array['bcode'][] = $arrAdd; + } + + return $barcode_array; + } + + //---------------------------------------------------------------------- + public static function clearCache() + { + self::$frames = array(); + } + + //---------------------------------------------------------------------- + public static function buildCache() + { + QRtools::markTime('before_build_cache'); + + $mask = new QRmask(); + for ($a=1; $a <= QRSPEC_VERSION_MAX; $a++) { + $frame = QRspec::newFrame($a); + if (QR_IMAGE) { + $fileName = QR_CACHE_DIR.'frame_'.$a.'.png'; + QRimage::png(self::binarize($frame), $fileName, 1, 0); + } + + $width = count($frame); + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + for ($maskNo=0; $maskNo<8; $maskNo++) + $mask->makeMaskNo($maskNo, $width, $frame, $bitMask, true); + } + + QRtools::markTime('after_build_cache'); + } + + //---------------------------------------------------------------------- + public static function log($outfile, $err) + { + if (QR_LOG_DIR !== false) { + if ($err != '') { + if ($outfile !== false) { + file_put_contents(QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); + } else { + file_put_contents(QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); + } + } + } + } + + //---------------------------------------------------------------------- + public static function dumpMask($frame) + { + $width = count($frame); + for($y=0;$y<$width;$y++) { + for($x=0;$x<$width;$x++) { + echo ord($frame[$y][$x]).','; + } + } + } + + //---------------------------------------------------------------------- + public static function markTime($markerId) + { + list($usec, $sec) = explode(" ", microtime()); + $time = ((float)$usec + (float)$sec); + + if (!isset($GLOBALS['qr_time_bench'])) + $GLOBALS['qr_time_bench'] = array(); + + $GLOBALS['qr_time_bench'][$markerId] = $time; + } + + //---------------------------------------------------------------------- + public static function timeBenchmark() + { + self::markTime('finish'); + + $lastTime = 0; + $startTime = 0; + $p = 0; + + echo ' + + '; + + foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) { + if ($p > 0) { + echo ''; + } else { + $startTime = $thisTime; + } + + $p++; + $lastTime = $thisTime; + } + + echo ' + + +
BENCHMARK
till '.$markerId.': '.number_format($thisTime-$lastTime, 6).'s
TOTAL: '.number_format($lastTime-$startTime, 6).'s
'; + } + + } + + //########################################################################## + + QRtools::markTime('start'); + + + + +//---- qrspec.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * QR Code specifications + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * The following data / specifications are taken from + * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) + * or + * "Automatic identification and data capture techniques -- + * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('QRSPEC_VERSION_MAX', 40); + define('QRSPEC_WIDTH_MAX', 177); + + define('QRCAP_WIDTH', 0); + define('QRCAP_WORDS', 1); + define('QRCAP_REMINDER', 2); + define('QRCAP_EC', 3); + + class QRspec { + + public static $capacity = array( + array( 0, 0, 0, array( 0, 0, 0, 0)), + array( 21, 26, 0, array( 7, 10, 13, 17)), // 1 + array( 25, 44, 7, array( 10, 16, 22, 28)), + array( 29, 70, 7, array( 15, 26, 36, 44)), + array( 33, 100, 7, array( 20, 36, 52, 64)), + array( 37, 134, 7, array( 26, 48, 72, 88)), // 5 + array( 41, 172, 7, array( 36, 64, 96, 112)), + array( 45, 196, 0, array( 40, 72, 108, 130)), + array( 49, 242, 0, array( 48, 88, 132, 156)), + array( 53, 292, 0, array( 60, 110, 160, 192)), + array( 57, 346, 0, array( 72, 130, 192, 224)), //10 + array( 61, 404, 0, array( 80, 150, 224, 264)), + array( 65, 466, 0, array( 96, 176, 260, 308)), + array( 69, 532, 0, array( 104, 198, 288, 352)), + array( 73, 581, 3, array( 120, 216, 320, 384)), + array( 77, 655, 3, array( 132, 240, 360, 432)), //15 + array( 81, 733, 3, array( 144, 280, 408, 480)), + array( 85, 815, 3, array( 168, 308, 448, 532)), + array( 89, 901, 3, array( 180, 338, 504, 588)), + array( 93, 991, 3, array( 196, 364, 546, 650)), + array( 97, 1085, 3, array( 224, 416, 600, 700)), //20 + array(101, 1156, 4, array( 224, 442, 644, 750)), + array(105, 1258, 4, array( 252, 476, 690, 816)), + array(109, 1364, 4, array( 270, 504, 750, 900)), + array(113, 1474, 4, array( 300, 560, 810, 960)), + array(117, 1588, 4, array( 312, 588, 870, 1050)), //25 + array(121, 1706, 4, array( 336, 644, 952, 1110)), + array(125, 1828, 4, array( 360, 700, 1020, 1200)), + array(129, 1921, 3, array( 390, 728, 1050, 1260)), + array(133, 2051, 3, array( 420, 784, 1140, 1350)), + array(137, 2185, 3, array( 450, 812, 1200, 1440)), //30 + array(141, 2323, 3, array( 480, 868, 1290, 1530)), + array(145, 2465, 3, array( 510, 924, 1350, 1620)), + array(149, 2611, 3, array( 540, 980, 1440, 1710)), + array(153, 2761, 3, array( 570, 1036, 1530, 1800)), + array(157, 2876, 0, array( 570, 1064, 1590, 1890)), //35 + array(161, 3034, 0, array( 600, 1120, 1680, 1980)), + array(165, 3196, 0, array( 630, 1204, 1770, 2100)), + array(169, 3362, 0, array( 660, 1260, 1860, 2220)), + array(173, 3532, 0, array( 720, 1316, 1950, 2310)), + array(177, 3706, 0, array( 750, 1372, 2040, 2430)) //40 + ); + + //---------------------------------------------------------------------- + public static function getDataLength($version, $level) + { + return self::$capacity[$version][QRCAP_WORDS] - self::$capacity[$version][QRCAP_EC][$level]; + } + + //---------------------------------------------------------------------- + public static function getECCLength($version, $level) + { + return self::$capacity[$version][QRCAP_EC][$level]; + } + + //---------------------------------------------------------------------- + public static function getWidth($version) + { + return self::$capacity[$version][QRCAP_WIDTH]; + } + + //---------------------------------------------------------------------- + public static function getRemainder($version) + { + return self::$capacity[$version][QRCAP_REMINDER]; + } + + //---------------------------------------------------------------------- + public static function getMinimumVersion($size, $level) + { + + for($i=1; $i<= QRSPEC_VERSION_MAX; $i++) { + $words = self::$capacity[$i][QRCAP_WORDS] - self::$capacity[$i][QRCAP_EC][$level]; + if($words >= $size) + return $i; + } + + return -1; + } + + //###################################################################### + + public static $lengthTableBits = array( + array(10, 12, 14), + array( 9, 11, 13), + array( 8, 16, 16), + array( 8, 10, 12) + ); + + //---------------------------------------------------------------------- + public static function lengthIndicator($mode, $version) + { + if ($mode == QR_MODE_STRUCTURE) + return 0; + + if ($version <= 9) { + $l = 0; + } else if ($version <= 26) { + $l = 1; + } else { + $l = 2; + } + + return self::$lengthTableBits[$mode][$l]; + } + + //---------------------------------------------------------------------- + public static function maximumWords($mode, $version) + { + if($mode == QR_MODE_STRUCTURE) + return 3; + + if($version <= 9) { + $l = 0; + } else if($version <= 26) { + $l = 1; + } else { + $l = 2; + } + + $bits = self::$lengthTableBits[$mode][$l]; + $words = (1 << $bits) - 1; + + if($mode == QR_MODE_KANJI) { + $words *= 2; // the number of bytes is required + } + + return $words; + } + + // Error correction code ----------------------------------------------- + // Table of the error correction code (Reed-Solomon block) + // See Table 12-16 (pp.30-36), JIS X0510:2004. + + public static $eccTable = array( + array(array( 0, 0), array( 0, 0), array( 0, 0), array( 0, 0)), + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), // 1 + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), + array(array( 1, 0), array( 1, 0), array( 2, 0), array( 2, 0)), + array(array( 1, 0), array( 2, 0), array( 2, 0), array( 4, 0)), + array(array( 1, 0), array( 2, 0), array( 2, 2), array( 2, 2)), // 5 + array(array( 2, 0), array( 4, 0), array( 4, 0), array( 4, 0)), + array(array( 2, 0), array( 4, 0), array( 2, 4), array( 4, 1)), + array(array( 2, 0), array( 2, 2), array( 4, 2), array( 4, 2)), + array(array( 2, 0), array( 3, 2), array( 4, 4), array( 4, 4)), + array(array( 2, 2), array( 4, 1), array( 6, 2), array( 6, 2)), //10 + array(array( 4, 0), array( 1, 4), array( 4, 4), array( 3, 8)), + array(array( 2, 2), array( 6, 2), array( 4, 6), array( 7, 4)), + array(array( 4, 0), array( 8, 1), array( 8, 4), array(12, 4)), + array(array( 3, 1), array( 4, 5), array(11, 5), array(11, 5)), + array(array( 5, 1), array( 5, 5), array( 5, 7), array(11, 7)), //15 + array(array( 5, 1), array( 7, 3), array(15, 2), array( 3, 13)), + array(array( 1, 5), array(10, 1), array( 1, 15), array( 2, 17)), + array(array( 5, 1), array( 9, 4), array(17, 1), array( 2, 19)), + array(array( 3, 4), array( 3, 11), array(17, 4), array( 9, 16)), + array(array( 3, 5), array( 3, 13), array(15, 5), array(15, 10)), //20 + array(array( 4, 4), array(17, 0), array(17, 6), array(19, 6)), + array(array( 2, 7), array(17, 0), array( 7, 16), array(34, 0)), + array(array( 4, 5), array( 4, 14), array(11, 14), array(16, 14)), + array(array( 6, 4), array( 6, 14), array(11, 16), array(30, 2)), + array(array( 8, 4), array( 8, 13), array( 7, 22), array(22, 13)), //25 + array(array(10, 2), array(19, 4), array(28, 6), array(33, 4)), + array(array( 8, 4), array(22, 3), array( 8, 26), array(12, 28)), + array(array( 3, 10), array( 3, 23), array( 4, 31), array(11, 31)), + array(array( 7, 7), array(21, 7), array( 1, 37), array(19, 26)), + array(array( 5, 10), array(19, 10), array(15, 25), array(23, 25)), //30 + array(array(13, 3), array( 2, 29), array(42, 1), array(23, 28)), + array(array(17, 0), array(10, 23), array(10, 35), array(19, 35)), + array(array(17, 1), array(14, 21), array(29, 19), array(11, 46)), + array(array(13, 6), array(14, 23), array(44, 7), array(59, 1)), + array(array(12, 7), array(12, 26), array(39, 14), array(22, 41)), //35 + array(array( 6, 14), array( 6, 34), array(46, 10), array( 2, 64)), + array(array(17, 4), array(29, 14), array(49, 10), array(24, 46)), + array(array( 4, 18), array(13, 32), array(48, 14), array(42, 32)), + array(array(20, 4), array(40, 7), array(43, 22), array(10, 67)), + array(array(19, 6), array(18, 31), array(34, 34), array(20, 61)),//40 + ); + + //---------------------------------------------------------------------- + // CACHEABLE!!! + + public static function getEccSpec($version, $level, array &$spec) + { + if (count($spec) < 5) { + $spec = array(0,0,0,0,0); + } + + $b1 = self::$eccTable[$version][$level][0]; + $b2 = self::$eccTable[$version][$level][1]; + $data = self::getDataLength($version, $level); + $ecc = self::getECCLength($version, $level); + + if($b2 == 0) { + $spec[0] = $b1; + $spec[1] = (int)($data / $b1); + $spec[2] = (int)($ecc / $b1); + $spec[3] = 0; + $spec[4] = 0; + } else { + $spec[0] = $b1; + $spec[1] = (int)($data / ($b1 + $b2)); + $spec[2] = (int)($ecc / ($b1 + $b2)); + $spec[3] = $b2; + $spec[4] = $spec[1] + 1; + } + } + + // Alignment pattern --------------------------------------------------- + + // Positions of alignment patterns. + // This array includes only the second and the third position of the + // alignment patterns. Rest of them can be calculated from the distance + // between them. + + // See Table 1 in Appendix E (pp.71) of JIS X0510:2004. + + public static $alignmentPattern = array( + array( 0, 0), + array( 0, 0), array(18, 0), array(22, 0), array(26, 0), array(30, 0), // 1- 5 + array(34, 0), array(22, 38), array(24, 42), array(26, 46), array(28, 50), // 6-10 + array(30, 54), array(32, 58), array(34, 62), array(26, 46), array(26, 48), //11-15 + array(26, 50), array(30, 54), array(30, 56), array(30, 58), array(34, 62), //16-20 + array(28, 50), array(26, 50), array(30, 54), array(28, 54), array(32, 58), //21-25 + array(30, 58), array(34, 62), array(26, 50), array(30, 54), array(26, 52), //26-30 + array(30, 56), array(34, 60), array(30, 58), array(34, 62), array(30, 54), //31-35 + array(24, 50), array(28, 54), array(32, 58), array(26, 54), array(30, 58), //35-40 + ); + + + /** -------------------------------------------------------------------- + * Put an alignment marker. + * @param frame + * @param width + * @param ox,oy center coordinate of the pattern + */ + public static function putAlignmentMarker(array &$frame, $ox, $oy) + { + $finder = array( + "\xa1\xa1\xa1\xa1\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa0\xa1\xa0\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa1\xa1\xa1\xa1" + ); + + $yStart = $oy-2; + $xStart = $ox-2; + + for($y=0; $y<5; $y++) { + QRstr::set($frame, $xStart, $yStart+$y, $finder[$y]); + } + } + + //---------------------------------------------------------------------- + public static function putAlignmentPattern($version, &$frame, $width) + { + if($version < 2) + return; + + $d = self::$alignmentPattern[$version][1] - self::$alignmentPattern[$version][0]; + if($d < 0) { + $w = 2; + } else { + $w = (int)(($width - self::$alignmentPattern[$version][0]) / $d + 2); + } + + if($w * $w - 3 == 1) { + $x = self::$alignmentPattern[$version][0]; + $y = self::$alignmentPattern[$version][0]; + self::putAlignmentMarker($frame, $x, $y); + return; + } + + $cx = self::$alignmentPattern[$version][0]; + for($x=1; $x<$w - 1; $x++) { + self::putAlignmentMarker($frame, 6, $cx); + self::putAlignmentMarker($frame, $cx, 6); + $cx += $d; + } + + $cy = self::$alignmentPattern[$version][0]; + for($y=0; $y<$w-1; $y++) { + $cx = self::$alignmentPattern[$version][0]; + for($x=0; $x<$w-1; $x++) { + self::putAlignmentMarker($frame, $cx, $cy); + $cx += $d; + } + $cy += $d; + } + } + + // Version information pattern ----------------------------------------- + + // Version information pattern (BCH coded). + // See Table 1 in Appendix D (pp.68) of JIS X0510:2004. + + // size: [QRSPEC_VERSION_MAX - 6] + + public static $versionPattern = array( + 0x07c94, 0x085bc, 0x09a99, 0x0a4d3, 0x0bbf6, 0x0c762, 0x0d847, 0x0e60d, + 0x0f928, 0x10b78, 0x1145d, 0x12a17, 0x13532, 0x149a6, 0x15683, 0x168c9, + 0x177ec, 0x18ec4, 0x191e1, 0x1afab, 0x1b08e, 0x1cc1a, 0x1d33f, 0x1ed75, + 0x1f250, 0x209d5, 0x216f0, 0x228ba, 0x2379f, 0x24b0b, 0x2542e, 0x26a64, + 0x27541, 0x28c69 + ); + + //---------------------------------------------------------------------- + public static function getVersionPattern($version) + { + if($version < 7 || $version > QRSPEC_VERSION_MAX) + return 0; + + return self::$versionPattern[$version -7]; + } + + // Format information -------------------------------------------------- + // See calcFormatInfo in tests/test_qrspec.c (orginal qrencode c lib) + + public static $formatInfo = array( + array(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976), + array(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0), + array(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed), + array(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b) + ); + + public static function getFormatInfo($mask, $level) + { + if($mask < 0 || $mask > 7) + return 0; + + if($level < 0 || $level > 3) + return 0; + + return self::$formatInfo[$level][$mask]; + } + + // Frame --------------------------------------------------------------- + // Cache of initial frames. + + public static $frames = array(); + + /** -------------------------------------------------------------------- + * Put a finder pattern. + * @param frame + * @param width + * @param ox,oy upper-left coordinate of the pattern + */ + public static function putFinderPattern(&$frame, $ox, $oy) + { + $finder = array( + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1" + ); + + for($y=0; $y<7; $y++) { + QRstr::set($frame, $ox, $oy+$y, $finder[$y]); + } + } + + //---------------------------------------------------------------------- + public static function createFrame($version) + { + $width = self::$capacity[$version][QRCAP_WIDTH]; + $frameLine = str_repeat ("\0", $width); + $frame = array_fill(0, $width, $frameLine); + + // Finder pattern + self::putFinderPattern($frame, 0, 0); + self::putFinderPattern($frame, $width - 7, 0); + self::putFinderPattern($frame, 0, $width - 7); + + // Separator + $yOffset = $width - 7; + + for($y=0; $y<7; $y++) { + $frame[$y][7] = "\xc0"; + $frame[$y][$width - 8] = "\xc0"; + $frame[$yOffset][7] = "\xc0"; + $yOffset++; + } + + $setPattern = str_repeat("\xc0", 8); + + QRstr::set($frame, 0, 7, $setPattern); + QRstr::set($frame, $width-8, 7, $setPattern); + QRstr::set($frame, 0, $width - 8, $setPattern); + + // Format info + $setPattern = str_repeat("\x84", 9); + QRstr::set($frame, 0, 8, $setPattern); + QRstr::set($frame, $width - 8, 8, $setPattern, 8); + + $yOffset = $width - 8; + + for($y=0; $y<8; $y++,$yOffset++) { + $frame[$y][8] = "\x84"; + $frame[$yOffset][8] = "\x84"; + } + + // Timing pattern + + for($i=1; $i<$width-15; $i++) { + $frame[6][7+$i] = chr(0x90 | ($i & 1)); + $frame[7+$i][6] = chr(0x90 | ($i & 1)); + } + + // Alignment pattern + self::putAlignmentPattern($version, $frame, $width); + + // Version information + if($version >= 7) { + $vinf = self::getVersionPattern($version); + + $v = $vinf; + + for($x=0; $x<6; $x++) { + for($y=0; $y<3; $y++) { + $frame[($width - 11)+$y][$x] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + + $v = $vinf; + for($y=0; $y<6; $y++) { + for($x=0; $x<3; $x++) { + $frame[$y][$x+($width - 11)] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + } + + // and a little bit... + $frame[$width - 8][8] = "\x81"; + + return $frame; + } + + //---------------------------------------------------------------------- + public static function debug($frame, $binary_mode = false) + { + if ($binary_mode) { + + foreach ($frame as &$frameLine) { + $frameLine = join('  ', explode('0', $frameLine)); + $frameLine = join('██', explode('1', $frameLine)); + } + + ?> + +


        '; + echo join("
        ", $frame); + echo '






'; + + } else { + + foreach ($frame as &$frameLine) { + $frameLine = join(' ', explode("\xc0", $frameLine)); + $frameLine = join('', explode("\xc1", $frameLine)); + $frameLine = join(' ', explode("\xa0", $frameLine)); + $frameLine = join('', explode("\xa1", $frameLine)); + $frameLine = join('', explode("\x84", $frameLine)); //format 0 + $frameLine = join('', explode("\x85", $frameLine)); //format 1 + $frameLine = join('', explode("\x81", $frameLine)); //special bit + $frameLine = join(' ', explode("\x90", $frameLine)); //clock 0 + $frameLine = join('', explode("\x91", $frameLine)); //clock 1 + $frameLine = join(' ', explode("\x88", $frameLine)); //version + $frameLine = join('', explode("\x89", $frameLine)); //version + $frameLine = join('♦', explode("\x01", $frameLine)); + $frameLine = join('⋅', explode("\0", $frameLine)); + } + + ?> + + "; + echo join("
", $frame); + echo "
"; + + } + } + + //---------------------------------------------------------------------- + public static function serial($frame) + { + return gzcompress(join("\n", $frame), 9); + } + + //---------------------------------------------------------------------- + public static function unserial($code) + { + return explode("\n", gzuncompress($code)); + } + + //---------------------------------------------------------------------- + public static function newFrame($version) + { + if($version < 1 || $version > QRSPEC_VERSION_MAX) + return null; + + if(!isset(self::$frames[$version])) { + + $fileName = QR_CACHE_DIR.'frame_'.$version.'.dat'; + + if (QR_CACHEABLE) { + if (file_exists($fileName)) { + self::$frames[$version] = self::unserial(file_get_contents($fileName)); + } else { + self::$frames[$version] = self::createFrame($version); + file_put_contents($fileName, self::serial(self::$frames[$version])); + } + } else { + self::$frames[$version] = self::createFrame($version); + } + } + + if(is_null(self::$frames[$version])) + return null; + + return self::$frames[$version]; + } + + //---------------------------------------------------------------------- + public static function rsBlockNum($spec) { return $spec[0] + $spec[3]; } + public static function rsBlockNum1($spec) { return $spec[0]; } + public static function rsDataCodes1($spec) { return $spec[1]; } + public static function rsEccCodes1($spec) { return $spec[2]; } + public static function rsBlockNum2($spec) { return $spec[3]; } + public static function rsDataCodes2($spec) { return $spec[4]; } + public static function rsEccCodes2($spec) { return $spec[2]; } + public static function rsDataLength($spec) { return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); } + public static function rsEccLength($spec) { return ($spec[0] + $spec[3]) * $spec[2]; } + + } + + + +//---- qrimage.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Image output of code using GD2 + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('QR_IMAGE', true); + + class QRimage { + + //---------------------------------------------------------------------- + public static function png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) + { + $image = self::image($frame, $pixelPerPoint, $outerFrame); + + if ($filename === false) { + Header("Content-type: image/png"); + ImagePng($image); + } else { + if($saveandprint===TRUE){ + ImagePng($image, $filename); + header("Content-type: image/png"); + ImagePng($image); + }else{ + ImagePng($image, $filename); + } + } + + ImageDestroy($image); + } + + //---------------------------------------------------------------------- + public static function jpg($frame, $filename = false, $pixelPerPoint = 8, $outerFrame = 4, $q = 85) + { + $image = self::image($frame, $pixelPerPoint, $outerFrame); + + if ($filename === false) { + Header("Content-type: image/jpeg"); + ImageJpeg($image, null, $q); + } else { + ImageJpeg($image, $filename, $q); + } + + ImageDestroy($image); + } + + //---------------------------------------------------------------------- + private static function image($frame, $pixelPerPoint = 4, $outerFrame = 4) + { + $h = count($frame); + $w = strlen($frame[0]); + + $imgW = $w + 2*$outerFrame; + $imgH = $h + 2*$outerFrame; + + $base_image =ImageCreate($imgW, $imgH); + + $col[0] = ImageColorAllocate($base_image,255,255,255); + $col[1] = ImageColorAllocate($base_image,0,0,0); + + imagefill($base_image, 0, 0, $col[0]); + + for($y=0; $y<$h; $y++) { + for($x=0; $x<$w; $x++) { + if ($frame[$y][$x] == '1') { + ImageSetPixel($base_image,$x+$outerFrame,$y+$outerFrame,$col[1]); + } + } + } + + $target_image =ImageCreate($imgW * $pixelPerPoint, $imgH * $pixelPerPoint); + ImageCopyResized($target_image, $base_image, 0, 0, 0, 0, $imgW * $pixelPerPoint, $imgH * $pixelPerPoint, $imgW, $imgH); + ImageDestroy($base_image); + + return $target_image; + } + } + + + +//---- qrinput.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Input encoding class + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('STRUCTURE_HEADER_BITS', 20); + define('MAX_STRUCTURED_SYMBOLS', 16); + + class QRinputItem { + + public $mode; + public $size; + public $data; + public $bstream; + + public function __construct($mode, $size, $data, $bstream = null) + { + $setData = array_slice($data, 0, $size); + + if (count($setData) < $size) { + $setData = array_merge($setData, array_fill(0,$size-count($setData),0)); + } + + if(!QRinput::check($mode, $size, $setData)) { + throw new Exception('Error m:'.$mode.',s:'.$size.',d:'.join(',',$setData)); + return null; + } + + $this->mode = $mode; + $this->size = $size; + $this->data = $setData; + $this->bstream = $bstream; + } + + //---------------------------------------------------------------------- + public function encodeModeNum($version) + { + try { + + $words = (int)($this->size / 3); + $bs = new QRbitstream(); + + $val = 0x1; + $bs->appendNum(4, $val); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_NUM, $version), $this->size); + + for($i=0; $i<$words; $i++) { + $val = (ord($this->data[$i*3 ]) - ord('0')) * 100; + $val += (ord($this->data[$i*3+1]) - ord('0')) * 10; + $val += (ord($this->data[$i*3+2]) - ord('0')); + $bs->appendNum(10, $val); + } + + if($this->size - $words * 3 == 1) { + $val = ord($this->data[$words*3]) - ord('0'); + $bs->appendNum(4, $val); + } else if($this->size - $words * 3 == 2) { + $val = (ord($this->data[$words*3 ]) - ord('0')) * 10; + $val += (ord($this->data[$words*3+1]) - ord('0')); + $bs->appendNum(7, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeAn($version) + { + try { + $words = (int)($this->size / 2); + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x02); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_AN, $version), $this->size); + + for($i=0; $i<$words; $i++) { + $val = (int)QRinput::lookAnTable(ord($this->data[$i*2 ])) * 45; + $val += (int)QRinput::lookAnTable(ord($this->data[$i*2+1])); + + $bs->appendNum(11, $val); + } + + if($this->size & 1) { + $val = QRinput::lookAnTable(ord($this->data[$words * 2])); + $bs->appendNum(6, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeMode8($version) + { + try { + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x4); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_8, $version), $this->size); + + for($i=0; $i<$this->size; $i++) { + $bs->appendNum(8, ord($this->data[$i])); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeKanji($version) + { + try { + + $bs = new QRbitrtream(); + + $bs->appendNum(4, 0x8); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_KANJI, $version), (int)($this->size / 2)); + + for($i=0; $i<$this->size; $i+=2) { + $val = (ord($this->data[$i]) << 8) | ord($this->data[$i+1]); + if($val <= 0x9ffc) { + $val -= 0x8140; + } else { + $val -= 0xc140; + } + + $h = ($val >> 8) * 0xc0; + $val = ($val & 0xff) + $h; + + $bs->appendNum(13, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeStructure() + { + try { + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x03); + $bs->appendNum(4, ord($this->data[1]) - 1); + $bs->appendNum(4, ord($this->data[0]) - 1); + $bs->appendNum(8, ord($this->data[2])); + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function estimateBitStreamSizeOfEntry($version) + { + $bits = 0; + + if($version == 0) + $version = 1; + + switch($this->mode) { + case QR_MODE_NUM: $bits = QRinput::estimateBitsModeNum($this->size); break; + case QR_MODE_AN: $bits = QRinput::estimateBitsModeAn($this->size); break; + case QR_MODE_8: $bits = QRinput::estimateBitsMode8($this->size); break; + case QR_MODE_KANJI: $bits = QRinput::estimateBitsModeKanji($this->size);break; + case QR_MODE_STRUCTURE: return STRUCTURE_HEADER_BITS; + default: + return 0; + } + + $l = QRspec::lengthIndicator($this->mode, $version); + $m = 1 << $l; + $num = (int)(($this->size + $m - 1) / $m); + + $bits += $num * (4 + $l); + + return $bits; + } + + //---------------------------------------------------------------------- + public function encodeBitStream($version) + { + try { + + unset($this->bstream); + $words = QRspec::maximumWords($this->mode, $version); + + if($this->size > $words) { + + $st1 = new QRinputItem($this->mode, $words, $this->data); + $st2 = new QRinputItem($this->mode, $this->size - $words, array_slice($this->data, $words)); + + $st1->encodeBitStream($version); + $st2->encodeBitStream($version); + + $this->bstream = new QRbitstream(); + $this->bstream->append($st1->bstream); + $this->bstream->append($st2->bstream); + + unset($st1); + unset($st2); + + } else { + + $ret = 0; + + switch($this->mode) { + case QR_MODE_NUM: $ret = $this->encodeModeNum($version); break; + case QR_MODE_AN: $ret = $this->encodeModeAn($version); break; + case QR_MODE_8: $ret = $this->encodeMode8($version); break; + case QR_MODE_KANJI: $ret = $this->encodeModeKanji($version);break; + case QR_MODE_STRUCTURE: $ret = $this->encodeModeStructure(); break; + + default: + break; + } + + if($ret < 0) + return -1; + } + + return $this->bstream->size(); + + } catch (Exception $e) { + return -1; + } + } + }; + + //########################################################################## + + class QRinput { + + public $items; + + private $version; + private $level; + + //---------------------------------------------------------------------- + public function __construct($version = 0, $level = QR_ECLEVEL_L) + { + if ($version < 0 || $version > QRSPEC_VERSION_MAX || $level > QR_ECLEVEL_H) { + throw new Exception('Invalid version no'); + return NULL; + } + + $this->version = $version; + $this->level = $level; + } + + //---------------------------------------------------------------------- + public function getVersion() + { + return $this->version; + } + + //---------------------------------------------------------------------- + public function setVersion($version) + { + if($version < 0 || $version > QRSPEC_VERSION_MAX) { + throw new Exception('Invalid version no'); + return -1; + } + + $this->version = $version; + + return 0; + } + + //---------------------------------------------------------------------- + public function getErrorCorrectionLevel() + { + return $this->level; + } + + //---------------------------------------------------------------------- + public function setErrorCorrectionLevel($level) + { + if($level > QR_ECLEVEL_H) { + throw new Exception('Invalid ECLEVEL'); + return -1; + } + + $this->level = $level; + + return 0; + } + + //---------------------------------------------------------------------- + public function appendEntry(QRinputItem $entry) + { + $this->items[] = $entry; + } + + //---------------------------------------------------------------------- + public function append($mode, $size, $data) + { + try { + $entry = new QRinputItem($mode, $size, $data); + $this->items[] = $entry; + return 0; + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + + public function insertStructuredAppendHeader($size, $index, $parity) + { + if( $size > MAX_STRUCTURED_SYMBOLS ) { + throw new Exception('insertStructuredAppendHeader wrong size'); + } + + if( $index <= 0 || $index > MAX_STRUCTURED_SYMBOLS ) { + throw new Exception('insertStructuredAppendHeader wrong index'); + } + + $buf = array($size, $index, $parity); + + try { + $entry = new QRinputItem(QR_MODE_STRUCTURE, 3, buf); + array_unshift($this->items, $entry); + return 0; + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function calcParity() + { + $parity = 0; + + foreach($this->items as $item) { + if($item->mode != QR_MODE_STRUCTURE) { + for($i=$item->size-1; $i>=0; $i--) { + $parity ^= $item->data[$i]; + } + } + } + + return $parity; + } + + //---------------------------------------------------------------------- + public static function checkModeNum($size, $data) + { + for($i=0; $i<$size; $i++) { + if((ord($data[$i]) < ord('0')) || (ord($data[$i]) > ord('9'))){ + return false; + } + } + + return true; + } + + //---------------------------------------------------------------------- + public static function estimateBitsModeNum($size) + { + $w = (int)$size / 3; + $bits = $w * 10; + + switch($size - $w * 3) { + case 1: + $bits += 4; + break; + case 2: + $bits += 7; + break; + default: + break; + } + + return $bits; + } + + //---------------------------------------------------------------------- + public static $anTable = array( + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, + -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, + 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 + ); + + //---------------------------------------------------------------------- + public static function lookAnTable($c) + { + return (($c > 127)?-1:self::$anTable[$c]); + } + + //---------------------------------------------------------------------- + public static function checkModeAn($size, $data) + { + for($i=0; $i<$size; $i++) { + if (self::lookAnTable(ord($data[$i])) == -1) { + return false; + } + } + + return true; + } + + //---------------------------------------------------------------------- + public static function estimateBitsModeAn($size) + { + $w = (int)($size / 2); + $bits = $w * 11; + + if($size & 1) { + $bits += 6; + } + + return $bits; + } + + //---------------------------------------------------------------------- + public static function estimateBitsMode8($size) + { + return $size * 8; + } + + //---------------------------------------------------------------------- + public function estimateBitsModeKanji($size) + { + return (int)(($size / 2) * 13); + } + + //---------------------------------------------------------------------- + public static function checkModeKanji($size, $data) + { + if($size & 1) + return false; + + for($i=0; $i<$size; $i+=2) { + $val = (ord($data[$i]) << 8) | ord($data[$i+1]); + if( $val < 0x8140 + || ($val > 0x9ffc && $val < 0xe040) + || $val > 0xebbf) { + return false; + } + } + + return true; + } + + /*********************************************************************** + * Validation + **********************************************************************/ + + public static function check($mode, $size, $data) + { + if($size <= 0) + return false; + + switch($mode) { + case QR_MODE_NUM: return self::checkModeNum($size, $data); break; + case QR_MODE_AN: return self::checkModeAn($size, $data); break; + case QR_MODE_KANJI: return self::checkModeKanji($size, $data); break; + case QR_MODE_8: return true; break; + case QR_MODE_STRUCTURE: return true; break; + + default: + break; + } + + return false; + } + + + //---------------------------------------------------------------------- + public function estimateBitStreamSize($version) + { + $bits = 0; + + foreach($this->items as $item) { + $bits += $item->estimateBitStreamSizeOfEntry($version); + } + + return $bits; + } + + //---------------------------------------------------------------------- + public function estimateVersion() + { + $version = 0; + $prev = 0; + do { + $prev = $version; + $bits = $this->estimateBitStreamSize($prev); + $version = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if ($version < 0) { + return -1; + } + } while ($version > $prev); + + return $version; + } + + //---------------------------------------------------------------------- + public static function lengthOfCode($mode, $version, $bits) + { + $payload = $bits - 4 - QRspec::lengthIndicator($mode, $version); + switch($mode) { + case QR_MODE_NUM: + $chunks = (int)($payload / 10); + $remain = $payload - $chunks * 10; + $size = $chunks * 3; + if($remain >= 7) { + $size += 2; + } else if($remain >= 4) { + $size += 1; + } + break; + case QR_MODE_AN: + $chunks = (int)($payload / 11); + $remain = $payload - $chunks * 11; + $size = $chunks * 2; + if($remain >= 6) + $size++; + break; + case QR_MODE_8: + $size = (int)($payload / 8); + break; + case QR_MODE_KANJI: + $size = (int)(($payload / 13) * 2); + break; + case QR_MODE_STRUCTURE: + $size = (int)($payload / 8); + break; + default: + $size = 0; + break; + } + + $maxsize = QRspec::maximumWords($mode, $version); + if($size < 0) $size = 0; + if($size > $maxsize) $size = $maxsize; + + return $size; + } + + //---------------------------------------------------------------------- + public function createBitStream() + { + $total = 0; + + foreach($this->items as $item) { + $bits = $item->encodeBitStream($this->version); + + if($bits < 0) + return -1; + + $total += $bits; + } + + return $total; + } + + //---------------------------------------------------------------------- + public function convertData() + { + $ver = $this->estimateVersion(); + if($ver > $this->getVersion()) { + $this->setVersion($ver); + } + + for(;;) { + $bits = $this->createBitStream(); + + if($bits < 0) + return -1; + + $ver = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if($ver < 0) { + throw new Exception('WRONG VERSION'); + return -1; + } else if($ver > $this->getVersion()) { + $this->setVersion($ver); + } else { + break; + } + } + + return 0; + } + + //---------------------------------------------------------------------- + public function appendPaddingBit(&$bstream) + { + $bits = $bstream->size(); + $maxwords = QRspec::getDataLength($this->version, $this->level); + $maxbits = $maxwords * 8; + + if ($maxbits == $bits) { + return 0; + } + + if ($maxbits - $bits < 5) { + return $bstream->appendNum($maxbits - $bits, 0); + } + + $bits += 4; + $words = (int)(($bits + 7) / 8); + + $padding = new QRbitstream(); + $ret = $padding->appendNum($words * 8 - $bits + 4, 0); + + if($ret < 0) + return $ret; + + $padlen = $maxwords - $words; + + if($padlen > 0) { + + $padbuf = array(); + for($i=0; $i<$padlen; $i++) { + $padbuf[$i] = ($i&1)?0x11:0xec; + } + + $ret = $padding->appendBytes($padlen, $padbuf); + + if($ret < 0) + return $ret; + + } + + $ret = $bstream->append($padding); + + return $ret; + } + + //---------------------------------------------------------------------- + public function mergeBitStream() + { + if($this->convertData() < 0) { + return null; + } + + $bstream = new QRbitstream(); + + foreach($this->items as $item) { + $ret = $bstream->append($item->bstream); + if($ret < 0) { + return null; + } + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function getBitStream() + { + + $bstream = $this->mergeBitStream(); + + if($bstream == null) { + return null; + } + + $ret = $this->appendPaddingBit($bstream); + if($ret < 0) { + return null; + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function getByteStream() + { + $bstream = $this->getBitStream(); + if($bstream == null) { + return null; + } + + return $bstream->toByte(); + } + } + + + + + + +//---- qrbitstream.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Bitstream class + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRbitstream { + + public $data = array(); + + //---------------------------------------------------------------------- + public function size() + { + return count($this->data); + } + + //---------------------------------------------------------------------- + public function allocate($setLength) + { + $this->data = array_fill(0, $setLength, 0); + return 0; + } + + //---------------------------------------------------------------------- + public static function newFromNum($bits, $num) + { + $bstream = new QRbitstream(); + $bstream->allocate($bits); + + $mask = 1 << ($bits - 1); + for($i=0; $i<$bits; $i++) { + if($num & $mask) { + $bstream->data[$i] = 1; + } else { + $bstream->data[$i] = 0; + } + $mask = $mask >> 1; + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public static function newFromBytes($size, $data) + { + $bstream = new QRbitstream(); + $bstream->allocate($size * 8); + $p=0; + + for($i=0; $i<$size; $i++) { + $mask = 0x80; + for($j=0; $j<8; $j++) { + if($data[$i] & $mask) { + $bstream->data[$p] = 1; + } else { + $bstream->data[$p] = 0; + } + $p++; + $mask = $mask >> 1; + } + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function append(QRbitstream $arg) + { + if (is_null($arg)) { + return -1; + } + + if($arg->size() == 0) { + return 0; + } + + if($this->size() == 0) { + $this->data = $arg->data; + return 0; + } + + $this->data = array_values(array_merge($this->data, $arg->data)); + + return 0; + } + + //---------------------------------------------------------------------- + public function appendNum($bits, $num) + { + if ($bits == 0) + return 0; + + $b = QRbitstream::newFromNum($bits, $num); + + if(is_null($b)) + return -1; + + $ret = $this->append($b); + unset($b); + + return $ret; + } + + //---------------------------------------------------------------------- + public function appendBytes($size, $data) + { + if ($size == 0) + return 0; + + $b = QRbitstream::newFromBytes($size, $data); + + if(is_null($b)) + return -1; + + $ret = $this->append($b); + unset($b); + + return $ret; + } + + //---------------------------------------------------------------------- + public function toByte() + { + + $size = $this->size(); + + if($size == 0) { + return array(); + } + + $data = array_fill(0, (int)(($size + 7) / 8), 0); + $bytes = (int)($size / 8); + + $p = 0; + + for($i=0; $i<$bytes; $i++) { + $v = 0; + for($j=0; $j<8; $j++) { + $v = $v << 1; + $v |= $this->data[$p]; + $p++; + } + $data[$i] = $v; + } + + if($size & 7) { + $v = 0; + for($j=0; $j<($size & 7); $j++) { + $v = $v << 1; + $v |= $this->data[$p]; + $p++; + } + $data[$bytes] = $v; + } + + return $data; + } + + } + + + + +//---- qrsplit.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Input splitting classes + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * The following data / specifications are taken from + * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) + * or + * "Automatic identification and data capture techniques -- + * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + class QRsplit { + + public $dataStr = ''; + public $input; + public $modeHint; + + //---------------------------------------------------------------------- + public function __construct($dataStr, $input, $modeHint) + { + $this->dataStr = $dataStr; + $this->input = $input; + $this->modeHint = $modeHint; + } + + //---------------------------------------------------------------------- + public static function isdigitat($str, $pos) + { + if ($pos >= strlen($str)) + return false; + + return ((ord($str[$pos]) >= ord('0'))&&(ord($str[$pos]) <= ord('9'))); + } + + //---------------------------------------------------------------------- + public static function isalnumat($str, $pos) + { + if ($pos >= strlen($str)) + return false; + + return (QRinput::lookAnTable(ord($str[$pos])) >= 0); + } + + //---------------------------------------------------------------------- + public function identifyMode($pos) + { + if ($pos >= strlen($this->dataStr)) + return QR_MODE_NUL; + + $c = $this->dataStr[$pos]; + + if(self::isdigitat($this->dataStr, $pos)) { + return QR_MODE_NUM; + } else if(self::isalnumat($this->dataStr, $pos)) { + return QR_MODE_AN; + } else if($this->modeHint == QR_MODE_KANJI) { + + if ($pos+1 < strlen($this->dataStr)) + { + $d = $this->dataStr[$pos+1]; + $word = (ord($c) << 8) | ord($d); + if(($word >= 0x8140 && $word <= 0x9ffc) || ($word >= 0xe040 && $word <= 0xebbf)) { + return QR_MODE_KANJI; + } + } + } + + return QR_MODE_8; + } + + //---------------------------------------------------------------------- + public function eatNum() + { + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 0; + while(self::isdigitat($this->dataStr, $p)) { + $p++; + } + + $run = $p; + $mode = $this->identifyMode($p); + + if($mode == QR_MODE_8) { + $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln + + QRinput::estimateBitsMode8(1) // + 4 + l8 + - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 + if($dif > 0) { + return $this->eat8(); + } + } + if($mode == QR_MODE_AN) { + $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln + + QRinput::estimateBitsModeAn(1) // + 4 + la + - QRinput::estimateBitsModeAn($run + 1);// - 4 - la + if($dif > 0) { + return $this->eatAn(); + } + } + + $ret = $this->input->append(QR_MODE_NUM, $run, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eatAn() + { + $la = QRspec::lengthIndicator(QR_MODE_AN, $this->input->getVersion()); + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 0; + + while(self::isalnumat($this->dataStr, $p)) { + if(self::isdigitat($this->dataStr, $p)) { + $q = $p; + while(self::isdigitat($this->dataStr, $q)) { + $q++; + } + + $dif = QRinput::estimateBitsModeAn($p) // + 4 + la + + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln + - QRinput::estimateBitsModeAn($q); // - 4 - la + + if($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + + $run = $p; + + if(!self::isalnumat($this->dataStr, $p)) { + $dif = QRinput::estimateBitsModeAn($run) + 4 + $la + + QRinput::estimateBitsMode8(1) // + 4 + l8 + - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 + if($dif > 0) { + return $this->eat8(); + } + } + + $ret = $this->input->append(QR_MODE_AN, $run, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eatKanji() + { + $p = 0; + + while($this->identifyMode($p) == QR_MODE_KANJI) { + $p += 2; + } + + $ret = $this->input->append(QR_MODE_KANJI, $p, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eat8() + { + $la = QRspec::lengthIndicator(QR_MODE_AN, $this->input->getVersion()); + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 1; + $dataStrLen = strlen($this->dataStr); + + while($p < $dataStrLen) { + + $mode = $this->identifyMode($p); + if($mode == QR_MODE_KANJI) { + break; + } + if($mode == QR_MODE_NUM) { + $q = $p; + while(self::isdigitat($this->dataStr, $q)) { + $q++; + } + $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 + + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln + - QRinput::estimateBitsMode8($q); // - 4 - l8 + if($dif < 0) { + break; + } else { + $p = $q; + } + } else if($mode == QR_MODE_AN) { + $q = $p; + while(self::isalnumat($this->dataStr, $q)) { + $q++; + } + $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 + + QRinput::estimateBitsModeAn($q - $p) + 4 + $la + - QRinput::estimateBitsMode8($q); // - 4 - l8 + if($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + + $run = $p; + $ret = $this->input->append(QR_MODE_8, $run, str_split($this->dataStr)); + + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function splitString() + { + while (strlen($this->dataStr) > 0) + { + if($this->dataStr == '') + return 0; + + $mode = $this->identifyMode(0); + + switch ($mode) { + case QR_MODE_NUM: $length = $this->eatNum(); break; + case QR_MODE_AN: $length = $this->eatAn(); break; + case QR_MODE_KANJI: + if ($hint == QR_MODE_KANJI) + $length = $this->eatKanji(); + else $length = $this->eat8(); + break; + default: $length = $this->eat8(); break; + + } + + if($length == 0) return 0; + if($length < 0) return -1; + + $this->dataStr = substr($this->dataStr, $length); + } + } + + //---------------------------------------------------------------------- + public function toUpper() + { + $stringLen = strlen($this->dataStr); + $p = 0; + + while ($p<$stringLen) { + $mode = self::identifyMode(substr($this->dataStr, $p), $this->modeHint); + if($mode == QR_MODE_KANJI) { + $p += 2; + } else { + if (ord($this->dataStr[$p]) >= ord('a') && ord($this->dataStr[$p]) <= ord('z')) { + $this->dataStr[$p] = chr(ord($this->dataStr[$p]) - 32); + } + $p++; + } + } + + return $this->dataStr; + } + + //---------------------------------------------------------------------- + public static function splitStringToQRinput($string, QRinput $input, $modeHint, $casesensitive = true) + { + if(is_null($string) || $string == '\0' || $string == '') { + throw new Exception('empty string!!!'); + } + + $split = new QRsplit($string, $input, $modeHint); + + if(!$casesensitive) + $split->toUpper(); + + return $split->splitString(); + } + } + + + +//---- qrrscode.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Reed-Solomon error correction support + * + * Copyright (C) 2002, 2003, 2004, 2006 Phil Karn, KA9Q + * (libfec is released under the GNU Lesser General Public License.) + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRrsItem { + + public $mm; // Bits per symbol + public $nn; // Symbols per block (= (1<= $this->nn) { + $x -= $this->nn; + $x = ($x >> $this->mm) + ($x & $this->nn); + } + + return $x; + } + + //---------------------------------------------------------------------- + public static function init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) + { + // Common code for intializing a Reed-Solomon control block (char or int symbols) + // Copyright 2004 Phil Karn, KA9Q + // May be used under the terms of the GNU Lesser General Public License (LGPL) + + $rs = null; + + // Check parameter ranges + if($symsize < 0 || $symsize > 8) return $rs; + if($fcr < 0 || $fcr >= (1<<$symsize)) return $rs; + if($prim <= 0 || $prim >= (1<<$symsize)) return $rs; + if($nroots < 0 || $nroots >= (1<<$symsize)) return $rs; // Can't have more roots than symbol values! + if($pad < 0 || $pad >= ((1<<$symsize) -1 - $nroots)) return $rs; // Too much padding + + $rs = new QRrsItem(); + $rs->mm = $symsize; + $rs->nn = (1<<$symsize)-1; + $rs->pad = $pad; + + $rs->alpha_to = array_fill(0, $rs->nn+1, 0); + $rs->index_of = array_fill(0, $rs->nn+1, 0); + + // PHP style macro replacement ;) + $NN =& $rs->nn; + $A0 =& $NN; + + // Generate Galois field lookup tables + $rs->index_of[0] = $A0; // log(zero) = -inf + $rs->alpha_to[$A0] = 0; // alpha**-inf = 0 + $sr = 1; + + for($i=0; $i<$rs->nn; $i++) { + $rs->index_of[$sr] = $i; + $rs->alpha_to[$i] = $sr; + $sr <<= 1; + if($sr & (1<<$symsize)) { + $sr ^= $gfpoly; + } + $sr &= $rs->nn; + } + + if($sr != 1){ + // field generator polynomial is not primitive! + $rs = NULL; + return $rs; + } + + /* Form RS code generator polynomial from its roots */ + $rs->genpoly = array_fill(0, $nroots+1, 0); + + $rs->fcr = $fcr; + $rs->prim = $prim; + $rs->nroots = $nroots; + $rs->gfpoly = $gfpoly; + + /* Find prim-th root of 1, used in decoding */ + for($iprim=1;($iprim % $prim) != 0;$iprim += $rs->nn) + ; // intentional empty-body loop! + + $rs->iprim = (int)($iprim / $prim); + $rs->genpoly[0] = 1; + + for ($i = 0,$root=$fcr*$prim; $i < $nroots; $i++, $root += $prim) { + $rs->genpoly[$i+1] = 1; + + // Multiply rs->genpoly[] by @**(root + x) + for ($j = $i; $j > 0; $j--) { + if ($rs->genpoly[$j] != 0) { + $rs->genpoly[$j] = $rs->genpoly[$j-1] ^ $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[$j]] + $root)]; + } else { + $rs->genpoly[$j] = $rs->genpoly[$j-1]; + } + } + // rs->genpoly[0] can never be zero + $rs->genpoly[0] = $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[0]] + $root)]; + } + + // convert rs->genpoly[] to index form for quicker encoding + for ($i = 0; $i <= $nroots; $i++) + $rs->genpoly[$i] = $rs->index_of[$rs->genpoly[$i]]; + + return $rs; + } + + //---------------------------------------------------------------------- + public function encode_rs_char($data, &$parity) + { + $MM =& $this->mm; + $NN =& $this->nn; + $ALPHA_TO =& $this->alpha_to; + $INDEX_OF =& $this->index_of; + $GENPOLY =& $this->genpoly; + $NROOTS =& $this->nroots; + $FCR =& $this->fcr; + $PRIM =& $this->prim; + $IPRIM =& $this->iprim; + $PAD =& $this->pad; + $A0 =& $NN; + + $parity = array_fill(0, $NROOTS, 0); + + for($i=0; $i< ($NN-$NROOTS-$PAD); $i++) { + + $feedback = $INDEX_OF[$data[$i] ^ $parity[0]]; + if($feedback != $A0) { + // feedback term is non-zero + + // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must + // always be for the polynomials constructed by init_rs() + $feedback = $this->modnn($NN - $GENPOLY[$NROOTS] + $feedback); + + for($j=1;$j<$NROOTS;$j++) { + $parity[$j] ^= $ALPHA_TO[$this->modnn($feedback + $GENPOLY[$NROOTS-$j])]; + } + } + + // Shift + array_shift($parity); + if($feedback != $A0) { + array_push($parity, $ALPHA_TO[$this->modnn($feedback + $GENPOLY[0])]); + } else { + array_push($parity, 0); + } + } + } + } + + //########################################################################## + + class QRrs { + + public static $items = array(); + + //---------------------------------------------------------------------- + public static function init_rs($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) + { + foreach(self::$items as $rs) { + if($rs->pad != $pad) continue; + if($rs->nroots != $nroots) continue; + if($rs->mm != $symsize) continue; + if($rs->gfpoly != $gfpoly) continue; + if($rs->fcr != $fcr) continue; + if($rs->prim != $prim) continue; + + return $rs; + } + + $rs = QRrsItem::init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad); + array_unshift(self::$items, $rs); + + return $rs; + } + } + + + +//---- qrmask.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Masking + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('N1', 3); + define('N2', 3); + define('N3', 40); + define('N4', 10); + + class QRmask { + + public $runLength = array(); + + //---------------------------------------------------------------------- + public function __construct() + { + $this->runLength = array_fill(0, QRSPEC_WIDTH_MAX + 1, 0); + } + + //---------------------------------------------------------------------- + public function writeFormatInformation($width, &$frame, $mask, $level) + { + $blacks = 0; + $format = QRspec::getFormatInfo($mask, $level); + + for($i=0; $i<8; $i++) { + if($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + + $frame[8][$width - 1 - $i] = chr($v); + if($i < 6) { + $frame[$i][8] = chr($v); + } else { + $frame[$i + 1][8] = chr($v); + } + $format = $format >> 1; + } + + for($i=0; $i<7; $i++) { + if($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + + $frame[$width - 7 + $i][8] = chr($v); + if($i == 0) { + $frame[8][7] = chr($v); + } else { + $frame[8][6 - $i] = chr($v); + } + + $format = $format >> 1; + } + + return $blacks; + } + + //---------------------------------------------------------------------- + public function mask0($x, $y) { return ($x+$y)&1; } + public function mask1($x, $y) { return ($y&1); } + public function mask2($x, $y) { return ($x%3); } + public function mask3($x, $y) { return ($x+$y)%3; } + public function mask4($x, $y) { return (((int)($y/2))+((int)($x/3)))&1; } + public function mask5($x, $y) { return (($x*$y)&1)+($x*$y)%3; } + public function mask6($x, $y) { return ((($x*$y)&1)+($x*$y)%3)&1; } + public function mask7($x, $y) { return ((($x*$y)%3)+(($x+$y)&1))&1; } + + //---------------------------------------------------------------------- + private function generateMaskNo($maskNo, $width, $frame) + { + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + + for($y=0; $y<$width; $y++) { + for($x=0; $x<$width; $x++) { + if(ord($frame[$y][$x]) & 0x80) { + $bitMask[$y][$x] = 0; + } else { + $maskFunc = call_user_func(array($this, 'mask'.$maskNo), $x, $y); + $bitMask[$y][$x] = ($maskFunc == 0)?1:0; + } + + } + } + + return $bitMask; + } + + //---------------------------------------------------------------------- + public static function serial($bitFrame) + { + $codeArr = array(); + + foreach ($bitFrame as $line) + $codeArr[] = join('', $line); + + return gzcompress(join("\n", $codeArr), 9); + } + + //---------------------------------------------------------------------- + public static function unserial($code) + { + $codeArr = array(); + + $codeLines = explode("\n", gzuncompress($code)); + foreach ($codeLines as $line) + $codeArr[] = str_split($line); + + return $codeArr; + } + + //---------------------------------------------------------------------- + public function makeMaskNo($maskNo, $width, $s, &$d, $maskGenOnly = false) + { + $b = 0; + $bitMask = array(); + + $fileName = QR_CACHE_DIR.'mask_'.$maskNo.DIRECTORY_SEPARATOR.'mask_'.$width.'_'.$maskNo.'.dat'; + + if (QR_CACHEABLE) { + if (file_exists($fileName)) { + $bitMask = self::unserial(file_get_contents($fileName)); + } else { + $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); + if (!file_exists(QR_CACHE_DIR.'mask_'.$maskNo)) + mkdir(QR_CACHE_DIR.'mask_'.$maskNo); + file_put_contents($fileName, self::serial($bitMask)); + } + } else { + $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); + } + + if ($maskGenOnly) + return; + + $d = $s; + + for($y=0; $y<$width; $y++) { + for($x=0; $x<$width; $x++) { + if($bitMask[$y][$x] == 1) { + $d[$y][$x] = chr(ord($s[$y][$x]) ^ (int)$bitMask[$y][$x]); + } + $b += (int)(ord($d[$y][$x]) & 1); + } + } + + return $b; + } + + //---------------------------------------------------------------------- + public function makeMask($width, $frame, $maskNo, $level) + { + $masked = array_fill(0, $width, str_repeat("\0", $width)); + $this->makeMaskNo($maskNo, $width, $frame, $masked); + $this->writeFormatInformation($width, $masked, $maskNo, $level); + + return $masked; + } + + //---------------------------------------------------------------------- + public function calcN1N3($length) + { + $demerit = 0; + + for($i=0; $i<$length; $i++) { + + if($this->runLength[$i] >= 5) { + $demerit += (N1 + ($this->runLength[$i] - 5)); + } + if($i & 1) { + if(($i >= 3) && ($i < ($length-2)) && ($this->runLength[$i] % 3 == 0)) { + $fact = (int)($this->runLength[$i] / 3); + if(($this->runLength[$i-2] == $fact) && + ($this->runLength[$i-1] == $fact) && + ($this->runLength[$i+1] == $fact) && + ($this->runLength[$i+2] == $fact)) { + if(($this->runLength[$i-3] < 0) || ($this->runLength[$i-3] >= (4 * $fact))) { + $demerit += N3; + } else if((($i+3) >= $length) || ($this->runLength[$i+3] >= (4 * $fact))) { + $demerit += N3; + } + } + } + } + } + return $demerit; + } + + //---------------------------------------------------------------------- + public function evaluateSymbol($width, $frame) + { + $head = 0; + $demerit = 0; + + for($y=0; $y<$width; $y++) { + $head = 0; + $this->runLength[0] = 1; + + $frameY = $frame[$y]; + + if ($y>0) + $frameYM = $frame[$y-1]; + + for($x=0; $x<$width; $x++) { + if(($x > 0) && ($y > 0)) { + $b22 = ord($frameY[$x]) & ord($frameY[$x-1]) & ord($frameYM[$x]) & ord($frameYM[$x-1]); + $w22 = ord($frameY[$x]) | ord($frameY[$x-1]) | ord($frameYM[$x]) | ord($frameYM[$x-1]); + + if(($b22 | ($w22 ^ 1))&1) { + $demerit += N2; + } + } + if(($x == 0) && (ord($frameY[$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } else if($x > 0) { + if((ord($frameY[$x]) ^ ord($frameY[$x-1])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + + $demerit += $this->calcN1N3($head+1); + } + + for($x=0; $x<$width; $x++) { + $head = 0; + $this->runLength[0] = 1; + + for($y=0; $y<$width; $y++) { + if($y == 0 && (ord($frame[$y][$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } else if($y > 0) { + if((ord($frame[$y][$x]) ^ ord($frame[$y-1][$x])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + + $demerit += $this->calcN1N3($head+1); + } + + return $demerit; + } + + + //---------------------------------------------------------------------- + public function mask($width, $frame, $level) + { + $minDemerit = PHP_INT_MAX; + $bestMaskNum = 0; + $bestMask = array(); + + $checked_masks = array(0,1,2,3,4,5,6,7); + + if (QR_FIND_FROM_RANDOM !== false) { + + $howManuOut = 8-(QR_FIND_FROM_RANDOM % 9); + for ($i = 0; $i < $howManuOut; $i++) { + $remPos = rand (0, count($checked_masks)-1); + unset($checked_masks[$remPos]); + $checked_masks = array_values($checked_masks); + } + + } + + $bestMask = $frame; + + foreach($checked_masks as $i) { + $mask = array_fill(0, $width, str_repeat("\0", $width)); + + $demerit = 0; + $blacks = 0; + $blacks = $this->makeMaskNo($i, $width, $frame, $mask); + $blacks += $this->writeFormatInformation($width, $mask, $i, $level); + $blacks = (int)(100 * $blacks / ($width * $width)); + $demerit = (int)((int)(abs($blacks - 50) / 5) * N4); + $demerit += $this->evaluateSymbol($width, $mask); + + if($demerit < $minDemerit) { + $minDemerit = $demerit; + $bestMask = $mask; + $bestMaskNum = $i; + } + } + + return $bestMask; + } + + //---------------------------------------------------------------------- + } + + + + +//---- qrencode.php ----------------------------- + + + + +/* + * PHP QR Code encoder + * + * Main encoder classes. + * + * Based on libqrencode C library distributed under LGPL 2.1 + * Copyright (C) 2006, 2007, 2008, 2009 Kentaro Fukuchi + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRrsblock { + public $dataLength; + public $data = array(); + public $eccLength; + public $ecc = array(); + + public function __construct($dl, $data, $el, &$ecc, QRrsItem $rs) + { + $rs->encode_rs_char($data, $ecc); + + $this->dataLength = $dl; + $this->data = $data; + $this->eccLength = $el; + $this->ecc = $ecc; + } + }; + + //########################################################################## + + class QRrawcode { + public $version; + public $datacode = array(); + public $ecccode = array(); + public $blocks; + public $rsblocks = array(); //of RSblock + public $count; + public $dataLength; + public $eccLength; + public $b1; + + //---------------------------------------------------------------------- + public function __construct(QRinput $input) + { + $spec = array(0,0,0,0,0); + + $this->datacode = $input->getByteStream(); + if(is_null($this->datacode)) { + throw new Exception('null imput string'); + } + + QRspec::getEccSpec($input->getVersion(), $input->getErrorCorrectionLevel(), $spec); + + $this->version = $input->getVersion(); + $this->b1 = QRspec::rsBlockNum1($spec); + $this->dataLength = QRspec::rsDataLength($spec); + $this->eccLength = QRspec::rsEccLength($spec); + $this->ecccode = array_fill(0, $this->eccLength, 0); + $this->blocks = QRspec::rsBlockNum($spec); + + $ret = $this->init($spec); + if($ret < 0) { + throw new Exception('block alloc error'); + return null; + } + + $this->count = 0; + } + + //---------------------------------------------------------------------- + public function init(array $spec) + { + $dl = QRspec::rsDataCodes1($spec); + $el = QRspec::rsEccCodes1($spec); + $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + + + $blockNo = 0; + $dataPos = 0; + $eccPos = 0; + for($i=0; $iecccode,$eccPos); + $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); + $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); + + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + + if(QRspec::rsBlockNum2($spec) == 0) + return 0; + + $dl = QRspec::rsDataCodes2($spec); + $el = QRspec::rsEccCodes2($spec); + $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + + if($rs == NULL) return -1; + + for($i=0; $iecccode,$eccPos); + $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); + $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); + + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + + return 0; + } + + //---------------------------------------------------------------------- + public function getCode() + { + $ret; + + if($this->count < $this->dataLength) { + $row = $this->count % $this->blocks; + $col = $this->count / $this->blocks; + if($col >= $this->rsblocks[0]->dataLength) { + $row += $this->b1; + } + $ret = $this->rsblocks[$row]->data[$col]; + } else if($this->count < $this->dataLength + $this->eccLength) { + $row = ($this->count - $this->dataLength) % $this->blocks; + $col = ($this->count - $this->dataLength) / $this->blocks; + $ret = $this->rsblocks[$row]->ecc[$col]; + } else { + return 0; + } + $this->count++; + + return $ret; + } + } + + //########################################################################## + + class QRcode { + + public $version; + public $width; + public $data; + + //---------------------------------------------------------------------- + public function encodeMask(QRinput $input, $mask) + { + if($input->getVersion() < 0 || $input->getVersion() > QRSPEC_VERSION_MAX) { + throw new Exception('wrong version'); + } + if($input->getErrorCorrectionLevel() > QR_ECLEVEL_H) { + throw new Exception('wrong level'); + } + + $raw = new QRrawcode($input); + + QRtools::markTime('after_raw'); + + $version = $raw->version; + $width = QRspec::getWidth($version); + $frame = QRspec::newFrame($version); + + $filler = new FrameFiller($width, $frame); + if(is_null($filler)) { + return NULL; + } + + // inteleaved data and ecc codes + for($i=0; $i<$raw->dataLength + $raw->eccLength; $i++) { + $code = $raw->getCode(); + $bit = 0x80; + for($j=0; $j<8; $j++) { + $addr = $filler->next(); + $filler->setFrameAt($addr, 0x02 | (($bit & $code) != 0)); + $bit = $bit >> 1; + } + } + + QRtools::markTime('after_filler'); + + unset($raw); + + // remainder bits + $j = QRspec::getRemainder($version); + for($i=0; $i<$j; $i++) { + $addr = $filler->next(); + $filler->setFrameAt($addr, 0x02); + } + + $frame = $filler->frame; + unset($filler); + + + // masking + $maskObj = new QRmask(); + if($mask < 0) { + + if (QR_FIND_BEST_MASK) { + $masked = $maskObj->mask($width, $frame, $input->getErrorCorrectionLevel()); + } else { + $masked = $maskObj->makeMask($width, $frame, (intval(QR_DEFAULT_MASK) % 8), $input->getErrorCorrectionLevel()); + } + } else { + $masked = $maskObj->makeMask($width, $frame, $mask, $input->getErrorCorrectionLevel()); + } + + if($masked == NULL) { + return NULL; + } + + QRtools::markTime('after_mask'); + + $this->version = $version; + $this->width = $width; + $this->data = $masked; + + return $this; + } + + //---------------------------------------------------------------------- + public function encodeInput(QRinput $input) + { + return $this->encodeMask($input, -1); + } + + //---------------------------------------------------------------------- + public function encodeString8bit($string, $version, $level) + { + if(string == NULL) { + throw new Exception('empty string!'); + return NULL; + } + + $input = new QRinput($version, $level); + if($input == NULL) return NULL; + + $ret = $input->append($input, QR_MODE_8, strlen($string), str_split($string)); + if($ret < 0) { + unset($input); + return NULL; + } + return $this->encodeInput($input); + } + + //---------------------------------------------------------------------- + public function encodeString($string, $version, $level, $hint, $casesensitive) + { + + if($hint != QR_MODE_8 && $hint != QR_MODE_KANJI) { + throw new Exception('bad hint'); + return NULL; + } + + $input = new QRinput($version, $level); + if($input == NULL) return NULL; + + $ret = QRsplit::splitStringToQRinput($string, $input, $hint, $casesensitive); + if($ret < 0) { + return NULL; + } + + return $this->encodeInput($input); + } + + //---------------------------------------------------------------------- + public static function png($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4, $saveandprint=false) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encodePNG($text, $outfile, $saveandprint=false); + } + + //---------------------------------------------------------------------- + public static function text($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encode($text, $outfile); + } + + //---------------------------------------------------------------------- + public static function raw($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encodeRAW($text, $outfile); + } + } + + //########################################################################## + + class FrameFiller { + + public $width; + public $frame; + public $x; + public $y; + public $dir; + public $bit; + + //---------------------------------------------------------------------- + public function __construct($width, &$frame) + { + $this->width = $width; + $this->frame = $frame; + $this->x = $width - 1; + $this->y = $width - 1; + $this->dir = -1; + $this->bit = -1; + } + + //---------------------------------------------------------------------- + public function setFrameAt($at, $val) + { + $this->frame[$at['y']][$at['x']] = chr($val); + } + + //---------------------------------------------------------------------- + public function getFrameAt($at) + { + return ord($this->frame[$at['y']][$at['x']]); + } + + //---------------------------------------------------------------------- + public function next() + { + do { + + if($this->bit == -1) { + $this->bit = 0; + return array('x'=>$this->x, 'y'=>$this->y); + } + + $x = $this->x; + $y = $this->y; + $w = $this->width; + + if($this->bit == 0) { + $x--; + $this->bit++; + } else { + $x++; + $y += $this->dir; + $this->bit--; + } + + if($this->dir < 0) { + if($y < 0) { + $y = 0; + $x -= 2; + $this->dir = 1; + if($x == 6) { + $x--; + $y = 9; + } + } + } else { + if($y == $w) { + $y = $w - 1; + $x -= 2; + $this->dir = -1; + if($x == 6) { + $x--; + $y -= 8; + } + } + } + if($x < 0 || $y < 0) return null; + + $this->x = $x; + $this->y = $y; + + } while(ord($this->frame[$y][$x]) & 0x80); + + return array('x'=>$x, 'y'=>$y); + } + + } ; + + //########################################################################## + + class QRencode { + + public $casesensitive = true; + public $eightbit = false; + + public $version = 0; + public $size = 3; + public $margin = 4; + + public $structured = 0; // not supported yet + + public $level = QR_ECLEVEL_L; + public $hint = QR_MODE_8; + + //---------------------------------------------------------------------- + public static function factory($level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = new QRencode(); + $enc->size = $size; + $enc->margin = $margin; + + switch ($level.'') { + case '0': + case '1': + case '2': + case '3': + $enc->level = $level; + break; + case 'l': + case 'L': + $enc->level = QR_ECLEVEL_L; + break; + case 'm': + case 'M': + $enc->level = QR_ECLEVEL_M; + break; + case 'q': + case 'Q': + $enc->level = QR_ECLEVEL_Q; + break; + case 'h': + case 'H': + $enc->level = QR_ECLEVEL_H; + break; + } + + return $enc; + } + + //---------------------------------------------------------------------- + public function encodeRAW($intext, $outfile = false) + { + $code = new QRcode(); + + if($this->eightbit) { + $code->encodeString8bit($intext, $this->version, $this->level); + } else { + $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); + } + + return $code->data; + } + + //---------------------------------------------------------------------- + public function encode($intext, $outfile = false) + { + $code = new QRcode(); + + if($this->eightbit) { + $code->encodeString8bit($intext, $this->version, $this->level); + } else { + $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); + } + + QRtools::markTime('after_encode'); + + if ($outfile!== false) { + file_put_contents($outfile, join("\n", QRtools::binarize($code->data))); + } else { + return QRtools::binarize($code->data); + } + } + + //---------------------------------------------------------------------- + public function encodePNG($intext, $outfile = false,$saveandprint=false) + { + try { + + ob_start(); + $tab = $this->encode($intext); + $err = ob_get_contents(); + ob_end_clean(); + + if ($err != '') + QRtools::log($outfile, $err); + + $maxSize = (int)(QR_PNG_MAXIMUM_SIZE / (count($tab)+2*$this->margin)); + + QRimage::png($tab, $outfile, min(max(1, $this->size), $maxSize), $this->margin,$saveandprint); + + } catch (Exception $e) { + + QRtools::log($outfile, $e->getMessage()); + + } + } + } + + diff --git a/src-backup/includes/phpqrcode/qr_18-10147_1765114124.png-errors.txt b/src-backup/includes/phpqrcode/qr_18-10147_1765114124.png-errors.txt new file mode 100644 index 0000000..5026e30 --- /dev/null +++ b/src-backup/includes/phpqrcode/qr_18-10147_1765114124.png-errors.txt @@ -0,0 +1,242 @@ +2025-12-07 21:28:44:
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 24.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 25.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 26.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 27.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 28.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 29.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 30.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 31.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 32.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 33.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 34.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 35.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 36.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 37.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 38.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 39.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 40.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 41.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 42.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 43.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 44.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 45.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 46.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 47.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 48.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 49.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 50.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 51.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 52.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 53.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 54.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 55.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 56.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 57.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 58.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 59.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 60.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 61.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 62.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 63.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 64.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 65.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 66.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 67.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 68.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 69.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 70.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 71.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 72.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 73.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 74.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 75.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 76.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 77.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 78.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 79.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 80.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 81.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 82.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 83.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 84.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 85.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 86.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 87.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 88.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 89.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 90.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 91.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 92.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 93.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 94.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 95.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 96.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
diff --git a/src-backup/includes/phpqrcode/qr_18-10147_1765114125.png-errors.txt b/src-backup/includes/phpqrcode/qr_18-10147_1765114125.png-errors.txt new file mode 100644 index 0000000..fa6939f --- /dev/null +++ b/src-backup/includes/phpqrcode/qr_18-10147_1765114125.png-errors.txt @@ -0,0 +1,242 @@ +2025-12-07 21:28:45:
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 24.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 25.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 26.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 27.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 28.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 29.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 30.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 31.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 32.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 33.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 34.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 35.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 36.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 37.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 38.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 39.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 40.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 41.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 42.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 43.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 44.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 45.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 46.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 47.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 48.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 49.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 50.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 51.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 52.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 53.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 54.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 55.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 56.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 57.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 58.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 59.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 60.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 61.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 62.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 63.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 64.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 65.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 66.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 67.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 68.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 69.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 70.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 71.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 72.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 73.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 74.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 75.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 76.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 77.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 78.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 79.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 80.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 81.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 82.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 83.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 84.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 85.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 86.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 87.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 88.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 89.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 90.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 91.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 92.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 93.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 94.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 95.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 96.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
diff --git a/src-backup/includes/phpqrcode/qr_18-10147_1765114249.png-errors.txt b/src-backup/includes/phpqrcode/qr_18-10147_1765114249.png-errors.txt new file mode 100644 index 0000000..c6d092b --- /dev/null +++ b/src-backup/includes/phpqrcode/qr_18-10147_1765114249.png-errors.txt @@ -0,0 +1,242 @@ +2025-12-07 21:30:49:
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 24.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 25.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 26.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 27.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 28.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 29.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 30.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 31.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 32.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 33.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 34.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 35.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 36.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 37.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 38.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 39.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 40.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 41.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 42.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 43.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 44.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 45.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 46.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 47.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 48.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 49.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 50.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 51.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 52.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 53.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 54.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 55.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 56.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 57.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 58.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 59.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 60.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 61.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 62.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 63.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 64.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 65.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 66.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 67.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 68.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 69.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 70.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 71.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 72.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 73.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 74.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 75.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 76.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 77.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 78.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 79.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 80.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 81.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 82.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 83.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 84.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 85.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 86.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 87.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 88.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 89.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 90.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 91.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 92.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 93.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 94.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 95.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 96.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 140
+
+Deprecated: Implicit conversion from float 0.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 1.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 2.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 3.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 4.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 5.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 6.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 7.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 8.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 9.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 10.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 11.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 12.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 13.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 14.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 15.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 16.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 17.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 18.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 19.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 20.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 21.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 22.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
+
+Deprecated: Implicit conversion from float 23.5 to int loses precision in C:\xampp\htdocs\attendance_system\includes\phpqrcode\qrencode.php on line 144
diff --git a/src-backup/includes/phpqrcode/qrbitstream.php b/src-backup/includes/phpqrcode/qrbitstream.php new file mode 100644 index 0000000..7d4ec4a --- /dev/null +++ b/src-backup/includes/phpqrcode/qrbitstream.php @@ -0,0 +1,180 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRbitstream { + + public $data = array(); + + //---------------------------------------------------------------------- + public function size() + { + return count($this->data); + } + + //---------------------------------------------------------------------- + public function allocate($setLength) + { + $this->data = array_fill(0, $setLength, 0); + return 0; + } + + //---------------------------------------------------------------------- + public static function newFromNum($bits, $num) + { + $bstream = new QRbitstream(); + $bstream->allocate($bits); + + $mask = 1 << ($bits - 1); + for($i=0; $i<$bits; $i++) { + if($num & $mask) { + $bstream->data[$i] = 1; + } else { + $bstream->data[$i] = 0; + } + $mask = $mask >> 1; + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public static function newFromBytes($size, $data) + { + $bstream = new QRbitstream(); + $bstream->allocate($size * 8); + $p=0; + + for($i=0; $i<$size; $i++) { + $mask = 0x80; + for($j=0; $j<8; $j++) { + if($data[$i] & $mask) { + $bstream->data[$p] = 1; + } else { + $bstream->data[$p] = 0; + } + $p++; + $mask = $mask >> 1; + } + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function append(QRbitstream $arg) + { + if (is_null($arg)) { + return -1; + } + + if($arg->size() == 0) { + return 0; + } + + if($this->size() == 0) { + $this->data = $arg->data; + return 0; + } + + $this->data = array_values(array_merge($this->data, $arg->data)); + + return 0; + } + + //---------------------------------------------------------------------- + public function appendNum($bits, $num) + { + if ($bits == 0) + return 0; + + $b = QRbitstream::newFromNum($bits, $num); + + if(is_null($b)) + return -1; + + $ret = $this->append($b); + unset($b); + + return $ret; + } + + //---------------------------------------------------------------------- + public function appendBytes($size, $data) + { + if ($size == 0) + return 0; + + $b = QRbitstream::newFromBytes($size, $data); + + if(is_null($b)) + return -1; + + $ret = $this->append($b); + unset($b); + + return $ret; + } + + //---------------------------------------------------------------------- + public function toByte() + { + + $size = $this->size(); + + if($size == 0) { + return array(); + } + + $data = array_fill(0, (int)(($size + 7) / 8), 0); + $bytes = (int)($size / 8); + + $p = 0; + + for($i=0; $i<$bytes; $i++) { + $v = 0; + for($j=0; $j<8; $j++) { + $v = $v << 1; + $v |= $this->data[$p]; + $p++; + } + $data[$i] = $v; + } + + if($size & 7) { + $v = 0; + for($j=0; $j<($size & 7); $j++) { + $v = $v << 1; + $v |= $this->data[$p]; + $p++; + } + $data[$bytes] = $v; + } + + return $data; + } + + } diff --git a/src-backup/includes/phpqrcode/qrconfig.php b/src-backup/includes/phpqrcode/qrconfig.php new file mode 100644 index 0000000..e53dff8 --- /dev/null +++ b/src-backup/includes/phpqrcode/qrconfig.php @@ -0,0 +1,17 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + // Encoding modes + + define('QR_MODE_NUL', -1); + define('QR_MODE_NUM', 0); + define('QR_MODE_AN', 1); + define('QR_MODE_8', 2); + define('QR_MODE_KANJI', 3); + define('QR_MODE_STRUCTURE', 4); + + // Levels of error correction. + + define('QR_ECLEVEL_L', 0); + define('QR_ECLEVEL_M', 1); + define('QR_ECLEVEL_Q', 2); + define('QR_ECLEVEL_H', 3); + + // Supported output formats + + define('QR_FORMAT_TEXT', 0); + define('QR_FORMAT_PNG', 1); + + class qrstr { + public static function set(&$srctab, $x, $y, $repl, $replLen = false) { + $srctab[$y] = substr_replace($srctab[$y], ($replLen !== false)?substr($repl,0,$replLen):$repl, $x, ($replLen !== false)?$replLen:strlen($repl)); + } + } \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrencode.php b/src-backup/includes/phpqrcode/qrencode.php new file mode 100644 index 0000000..4b77a5b --- /dev/null +++ b/src-backup/includes/phpqrcode/qrencode.php @@ -0,0 +1,502 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRrsblock { + public $dataLength; + public $data = array(); + public $eccLength; + public $ecc = array(); + + public function __construct($dl, $data, $el, &$ecc, QRrsItem $rs) + { + $rs->encode_rs_char($data, $ecc); + + $this->dataLength = $dl; + $this->data = $data; + $this->eccLength = $el; + $this->ecc = $ecc; + } + }; + + //########################################################################## + + class QRrawcode { + public $version; + public $datacode = array(); + public $ecccode = array(); + public $blocks; + public $rsblocks = array(); //of RSblock + public $count; + public $dataLength; + public $eccLength; + public $b1; + + //---------------------------------------------------------------------- + public function __construct(QRinput $input) + { + $spec = array(0,0,0,0,0); + + $this->datacode = $input->getByteStream(); + if(is_null($this->datacode)) { + throw new Exception('null imput string'); + } + + QRspec::getEccSpec($input->getVersion(), $input->getErrorCorrectionLevel(), $spec); + + $this->version = $input->getVersion(); + $this->b1 = QRspec::rsBlockNum1($spec); + $this->dataLength = QRspec::rsDataLength($spec); + $this->eccLength = QRspec::rsEccLength($spec); + $this->ecccode = array_fill(0, $this->eccLength, 0); + $this->blocks = QRspec::rsBlockNum($spec); + + $ret = $this->init($spec); + if($ret < 0) { + throw new Exception('block alloc error'); + return null; + } + + $this->count = 0; + } + + //---------------------------------------------------------------------- + public function init(array $spec) + { + $dl = QRspec::rsDataCodes1($spec); + $el = QRspec::rsEccCodes1($spec); + $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + + + $blockNo = 0; + $dataPos = 0; + $eccPos = 0; + for($i=0; $iecccode,$eccPos); + $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); + $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); + + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + + if(QRspec::rsBlockNum2($spec) == 0) + return 0; + + $dl = QRspec::rsDataCodes2($spec); + $el = QRspec::rsEccCodes2($spec); + $rs = QRrs::init_rs(8, 0x11d, 0, 1, $el, 255 - $dl - $el); + + if($rs == NULL) return -1; + + for($i=0; $iecccode,$eccPos); + $this->rsblocks[$blockNo] = new QRrsblock($dl, array_slice($this->datacode, $dataPos), $el, $ecc, $rs); + $this->ecccode = array_merge(array_slice($this->ecccode,0, $eccPos), $ecc); + + $dataPos += $dl; + $eccPos += $el; + $blockNo++; + } + + return 0; + } + + //---------------------------------------------------------------------- + public function getCode() + { + $ret; + + if($this->count < $this->dataLength) { + $row = $this->count % $this->blocks; + $col = $this->count / $this->blocks; + if($col >= $this->rsblocks[0]->dataLength) { + $row += $this->b1; + } + $ret = $this->rsblocks[$row]->data[$col]; + } else if($this->count < $this->dataLength + $this->eccLength) { + $row = ($this->count - $this->dataLength) % $this->blocks; + $col = ($this->count - $this->dataLength) / $this->blocks; + $ret = $this->rsblocks[$row]->ecc[$col]; + } else { + return 0; + } + $this->count++; + + return $ret; + } + } + + //########################################################################## + + class QRcode { + + public $version; + public $width; + public $data; + + //---------------------------------------------------------------------- + public function encodeMask(QRinput $input, $mask) + { + if($input->getVersion() < 0 || $input->getVersion() > QRSPEC_VERSION_MAX) { + throw new Exception('wrong version'); + } + if($input->getErrorCorrectionLevel() > QR_ECLEVEL_H) { + throw new Exception('wrong level'); + } + + $raw = new QRrawcode($input); + + QRtools::markTime('after_raw'); + + $version = $raw->version; + $width = QRspec::getWidth($version); + $frame = QRspec::newFrame($version); + + $filler = new FrameFiller($width, $frame); + if(is_null($filler)) { + return NULL; + } + + // inteleaved data and ecc codes + for($i=0; $i<$raw->dataLength + $raw->eccLength; $i++) { + $code = $raw->getCode(); + $bit = 0x80; + for($j=0; $j<8; $j++) { + $addr = $filler->next(); + $filler->setFrameAt($addr, 0x02 | (($bit & $code) != 0)); + $bit = $bit >> 1; + } + } + + QRtools::markTime('after_filler'); + + unset($raw); + + // remainder bits + $j = QRspec::getRemainder($version); + for($i=0; $i<$j; $i++) { + $addr = $filler->next(); + $filler->setFrameAt($addr, 0x02); + } + + $frame = $filler->frame; + unset($filler); + + + // masking + $maskObj = new QRmask(); + if($mask < 0) { + + if (QR_FIND_BEST_MASK) { + $masked = $maskObj->mask($width, $frame, $input->getErrorCorrectionLevel()); + } else { + $masked = $maskObj->makeMask($width, $frame, (intval(QR_DEFAULT_MASK) % 8), $input->getErrorCorrectionLevel()); + } + } else { + $masked = $maskObj->makeMask($width, $frame, $mask, $input->getErrorCorrectionLevel()); + } + + if($masked == NULL) { + return NULL; + } + + QRtools::markTime('after_mask'); + + $this->version = $version; + $this->width = $width; + $this->data = $masked; + + return $this; + } + + //---------------------------------------------------------------------- + public function encodeInput(QRinput $input) + { + return $this->encodeMask($input, -1); + } + + //---------------------------------------------------------------------- + public function encodeString8bit($string, $version, $level) + { + if(string == NULL) { + throw new Exception('empty string!'); + return NULL; + } + + $input = new QRinput($version, $level); + if($input == NULL) return NULL; + + $ret = $input->append($input, QR_MODE_8, strlen($string), str_split($string)); + if($ret < 0) { + unset($input); + return NULL; + } + return $this->encodeInput($input); + } + + //---------------------------------------------------------------------- + public function encodeString($string, $version, $level, $hint, $casesensitive) + { + + if($hint != QR_MODE_8 && $hint != QR_MODE_KANJI) { + throw new Exception('bad hint'); + return NULL; + } + + $input = new QRinput($version, $level); + if($input == NULL) return NULL; + + $ret = QRsplit::splitStringToQRinput($string, $input, $hint, $casesensitive); + if($ret < 0) { + return NULL; + } + + return $this->encodeInput($input); + } + + //---------------------------------------------------------------------- + public static function png($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4, $saveandprint=false) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encodePNG($text, $outfile, $saveandprint=false); + } + + //---------------------------------------------------------------------- + public static function text($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encode($text, $outfile); + } + + //---------------------------------------------------------------------- + public static function raw($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = QRencode::factory($level, $size, $margin); + return $enc->encodeRAW($text, $outfile); + } + } + + //########################################################################## + + class FrameFiller { + + public $width; + public $frame; + public $x; + public $y; + public $dir; + public $bit; + + //---------------------------------------------------------------------- + public function __construct($width, &$frame) + { + $this->width = $width; + $this->frame = $frame; + $this->x = $width - 1; + $this->y = $width - 1; + $this->dir = -1; + $this->bit = -1; + } + + //---------------------------------------------------------------------- + public function setFrameAt($at, $val) + { + $this->frame[$at['y']][$at['x']] = chr($val); + } + + //---------------------------------------------------------------------- + public function getFrameAt($at) + { + return ord($this->frame[$at['y']][$at['x']]); + } + + //---------------------------------------------------------------------- + public function next() + { + do { + + if($this->bit == -1) { + $this->bit = 0; + return array('x'=>$this->x, 'y'=>$this->y); + } + + $x = $this->x; + $y = $this->y; + $w = $this->width; + + if($this->bit == 0) { + $x--; + $this->bit++; + } else { + $x++; + $y += $this->dir; + $this->bit--; + } + + if($this->dir < 0) { + if($y < 0) { + $y = 0; + $x -= 2; + $this->dir = 1; + if($x == 6) { + $x--; + $y = 9; + } + } + } else { + if($y == $w) { + $y = $w - 1; + $x -= 2; + $this->dir = -1; + if($x == 6) { + $x--; + $y -= 8; + } + } + } + if($x < 0 || $y < 0) return null; + + $this->x = $x; + $this->y = $y; + + } while(ord($this->frame[$y][$x]) & 0x80); + + return array('x'=>$x, 'y'=>$y); + } + + } ; + + //########################################################################## + + class QRencode { + + public $casesensitive = true; + public $eightbit = false; + + public $version = 0; + public $size = 3; + public $margin = 4; + + public $structured = 0; // not supported yet + + public $level = QR_ECLEVEL_L; + public $hint = QR_MODE_8; + + //---------------------------------------------------------------------- + public static function factory($level = QR_ECLEVEL_L, $size = 3, $margin = 4) + { + $enc = new QRencode(); + $enc->size = $size; + $enc->margin = $margin; + + switch ($level.'') { + case '0': + case '1': + case '2': + case '3': + $enc->level = $level; + break; + case 'l': + case 'L': + $enc->level = QR_ECLEVEL_L; + break; + case 'm': + case 'M': + $enc->level = QR_ECLEVEL_M; + break; + case 'q': + case 'Q': + $enc->level = QR_ECLEVEL_Q; + break; + case 'h': + case 'H': + $enc->level = QR_ECLEVEL_H; + break; + } + + return $enc; + } + + //---------------------------------------------------------------------- + public function encodeRAW($intext, $outfile = false) + { + $code = new QRcode(); + + if($this->eightbit) { + $code->encodeString8bit($intext, $this->version, $this->level); + } else { + $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); + } + + return $code->data; + } + + //---------------------------------------------------------------------- + public function encode($intext, $outfile = false) + { + $code = new QRcode(); + + if($this->eightbit) { + $code->encodeString8bit($intext, $this->version, $this->level); + } else { + $code->encodeString($intext, $this->version, $this->level, $this->hint, $this->casesensitive); + } + + QRtools::markTime('after_encode'); + + if ($outfile!== false) { + file_put_contents($outfile, join("\n", QRtools::binarize($code->data))); + } else { + return QRtools::binarize($code->data); + } + } + + //---------------------------------------------------------------------- + public function encodePNG($intext, $outfile = false,$saveandprint=false) + { + try { + + ob_start(); + $tab = $this->encode($intext); + $err = ob_get_contents(); + ob_end_clean(); + + if ($err != '') + QRtools::log($outfile, $err); + + $maxSize = (int)(QR_PNG_MAXIMUM_SIZE / (count($tab)+2*$this->margin)); + + QRimage::png($tab, $outfile, min(max(1, $this->size), $maxSize), $this->margin,$saveandprint); + + } catch (Exception $e) { + + QRtools::log($outfile, $e->getMessage()); + + } + } + } diff --git a/src-backup/includes/phpqrcode/qrimage.php b/src-backup/includes/phpqrcode/qrimage.php new file mode 100644 index 0000000..10b0a6e --- /dev/null +++ b/src-backup/includes/phpqrcode/qrimage.php @@ -0,0 +1,95 @@ + + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('QR_IMAGE', true); + + class QRimage { + + //---------------------------------------------------------------------- + public static function png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) + { + $image = self::image($frame, $pixelPerPoint, $outerFrame); + + if ($filename === false) { + Header("Content-type: image/png"); + ImagePng($image); + } else { + if($saveandprint===TRUE){ + ImagePng($image, $filename); + header("Content-type: image/png"); + ImagePng($image); + }else{ + ImagePng($image, $filename); + } + } + + ImageDestroy($image); + } + + //---------------------------------------------------------------------- + public static function jpg($frame, $filename = false, $pixelPerPoint = 8, $outerFrame = 4, $q = 85) + { + $image = self::image($frame, $pixelPerPoint, $outerFrame); + + if ($filename === false) { + Header("Content-type: image/jpeg"); + ImageJpeg($image, null, $q); + } else { + ImageJpeg($image, $filename, $q); + } + + ImageDestroy($image); + } + + //---------------------------------------------------------------------- + private static function image($frame, $pixelPerPoint = 4, $outerFrame = 4) + { + $h = count($frame); + $w = strlen($frame[0]); + + $imgW = $w + 2*$outerFrame; + $imgH = $h + 2*$outerFrame; + + $base_image =ImageCreate($imgW, $imgH); + + $col[0] = ImageColorAllocate($base_image,255,255,255); + $col[1] = ImageColorAllocate($base_image,0,0,0); + + imagefill($base_image, 0, 0, $col[0]); + + for($y=0; $y<$h; $y++) { + for($x=0; $x<$w; $x++) { + if ($frame[$y][$x] == '1') { + ImageSetPixel($base_image,$x+$outerFrame,$y+$outerFrame,$col[1]); + } + } + } + + $target_image =ImageCreate($imgW * $pixelPerPoint, $imgH * $pixelPerPoint); + ImageCopyResized($target_image, $base_image, 0, 0, 0, 0, $imgW * $pixelPerPoint, $imgH * $pixelPerPoint, $imgW, $imgH); + ImageDestroy($base_image); + + return $target_image; + } + } \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrinput.php b/src-backup/includes/phpqrcode/qrinput.php new file mode 100644 index 0000000..0f6d7f9 --- /dev/null +++ b/src-backup/includes/phpqrcode/qrinput.php @@ -0,0 +1,729 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('STRUCTURE_HEADER_BITS', 20); + define('MAX_STRUCTURED_SYMBOLS', 16); + + class QRinputItem { + + public $mode; + public $size; + public $data; + public $bstream; + + public function __construct($mode, $size, $data, $bstream = null) + { + $setData = array_slice($data, 0, $size); + + if (count($setData) < $size) { + $setData = array_merge($setData, array_fill(0,$size-count($setData),0)); + } + + if(!QRinput::check($mode, $size, $setData)) { + throw new Exception('Error m:'.$mode.',s:'.$size.',d:'.join(',',$setData)); + return null; + } + + $this->mode = $mode; + $this->size = $size; + $this->data = $setData; + $this->bstream = $bstream; + } + + //---------------------------------------------------------------------- + public function encodeModeNum($version) + { + try { + + $words = (int)($this->size / 3); + $bs = new QRbitstream(); + + $val = 0x1; + $bs->appendNum(4, $val); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_NUM, $version), $this->size); + + for($i=0; $i<$words; $i++) { + $val = (ord($this->data[$i*3 ]) - ord('0')) * 100; + $val += (ord($this->data[$i*3+1]) - ord('0')) * 10; + $val += (ord($this->data[$i*3+2]) - ord('0')); + $bs->appendNum(10, $val); + } + + if($this->size - $words * 3 == 1) { + $val = ord($this->data[$words*3]) - ord('0'); + $bs->appendNum(4, $val); + } else if($this->size - $words * 3 == 2) { + $val = (ord($this->data[$words*3 ]) - ord('0')) * 10; + $val += (ord($this->data[$words*3+1]) - ord('0')); + $bs->appendNum(7, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeAn($version) + { + try { + $words = (int)($this->size / 2); + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x02); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_AN, $version), $this->size); + + for($i=0; $i<$words; $i++) { + $val = (int)QRinput::lookAnTable(ord($this->data[$i*2 ])) * 45; + $val += (int)QRinput::lookAnTable(ord($this->data[$i*2+1])); + + $bs->appendNum(11, $val); + } + + if($this->size & 1) { + $val = QRinput::lookAnTable(ord($this->data[$words * 2])); + $bs->appendNum(6, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeMode8($version) + { + try { + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x4); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_8, $version), $this->size); + + for($i=0; $i<$this->size; $i++) { + $bs->appendNum(8, ord($this->data[$i])); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeKanji($version) + { + try { + + $bs = new QRbitrtream(); + + $bs->appendNum(4, 0x8); + $bs->appendNum(QRspec::lengthIndicator(QR_MODE_KANJI, $version), (int)($this->size / 2)); + + for($i=0; $i<$this->size; $i+=2) { + $val = (ord($this->data[$i]) << 8) | ord($this->data[$i+1]); + if($val <= 0x9ffc) { + $val -= 0x8140; + } else { + $val -= 0xc140; + } + + $h = ($val >> 8) * 0xc0; + $val = ($val & 0xff) + $h; + + $bs->appendNum(13, $val); + } + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function encodeModeStructure() + { + try { + $bs = new QRbitstream(); + + $bs->appendNum(4, 0x03); + $bs->appendNum(4, ord($this->data[1]) - 1); + $bs->appendNum(4, ord($this->data[0]) - 1); + $bs->appendNum(8, ord($this->data[2])); + + $this->bstream = $bs; + return 0; + + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function estimateBitStreamSizeOfEntry($version) + { + $bits = 0; + + if($version == 0) + $version = 1; + + switch($this->mode) { + case QR_MODE_NUM: $bits = QRinput::estimateBitsModeNum($this->size); break; + case QR_MODE_AN: $bits = QRinput::estimateBitsModeAn($this->size); break; + case QR_MODE_8: $bits = QRinput::estimateBitsMode8($this->size); break; + case QR_MODE_KANJI: $bits = QRinput::estimateBitsModeKanji($this->size);break; + case QR_MODE_STRUCTURE: return STRUCTURE_HEADER_BITS; + default: + return 0; + } + + $l = QRspec::lengthIndicator($this->mode, $version); + $m = 1 << $l; + $num = (int)(($this->size + $m - 1) / $m); + + $bits += $num * (4 + $l); + + return $bits; + } + + //---------------------------------------------------------------------- + public function encodeBitStream($version) + { + try { + + unset($this->bstream); + $words = QRspec::maximumWords($this->mode, $version); + + if($this->size > $words) { + + $st1 = new QRinputItem($this->mode, $words, $this->data); + $st2 = new QRinputItem($this->mode, $this->size - $words, array_slice($this->data, $words)); + + $st1->encodeBitStream($version); + $st2->encodeBitStream($version); + + $this->bstream = new QRbitstream(); + $this->bstream->append($st1->bstream); + $this->bstream->append($st2->bstream); + + unset($st1); + unset($st2); + + } else { + + $ret = 0; + + switch($this->mode) { + case QR_MODE_NUM: $ret = $this->encodeModeNum($version); break; + case QR_MODE_AN: $ret = $this->encodeModeAn($version); break; + case QR_MODE_8: $ret = $this->encodeMode8($version); break; + case QR_MODE_KANJI: $ret = $this->encodeModeKanji($version);break; + case QR_MODE_STRUCTURE: $ret = $this->encodeModeStructure(); break; + + default: + break; + } + + if($ret < 0) + return -1; + } + + return $this->bstream->size(); + + } catch (Exception $e) { + return -1; + } + } + }; + + //########################################################################## + + class QRinput { + + public $items; + + private $version; + private $level; + + //---------------------------------------------------------------------- + public function __construct($version = 0, $level = QR_ECLEVEL_L) + { + if ($version < 0 || $version > QRSPEC_VERSION_MAX || $level > QR_ECLEVEL_H) { + throw new Exception('Invalid version no'); + return NULL; + } + + $this->version = $version; + $this->level = $level; + } + + //---------------------------------------------------------------------- + public function getVersion() + { + return $this->version; + } + + //---------------------------------------------------------------------- + public function setVersion($version) + { + if($version < 0 || $version > QRSPEC_VERSION_MAX) { + throw new Exception('Invalid version no'); + return -1; + } + + $this->version = $version; + + return 0; + } + + //---------------------------------------------------------------------- + public function getErrorCorrectionLevel() + { + return $this->level; + } + + //---------------------------------------------------------------------- + public function setErrorCorrectionLevel($level) + { + if($level > QR_ECLEVEL_H) { + throw new Exception('Invalid ECLEVEL'); + return -1; + } + + $this->level = $level; + + return 0; + } + + //---------------------------------------------------------------------- + public function appendEntry(QRinputItem $entry) + { + $this->items[] = $entry; + } + + //---------------------------------------------------------------------- + public function append($mode, $size, $data) + { + try { + $entry = new QRinputItem($mode, $size, $data); + $this->items[] = $entry; + return 0; + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + + public function insertStructuredAppendHeader($size, $index, $parity) + { + if( $size > MAX_STRUCTURED_SYMBOLS ) { + throw new Exception('insertStructuredAppendHeader wrong size'); + } + + if( $index <= 0 || $index > MAX_STRUCTURED_SYMBOLS ) { + throw new Exception('insertStructuredAppendHeader wrong index'); + } + + $buf = array($size, $index, $parity); + + try { + $entry = new QRinputItem(QR_MODE_STRUCTURE, 3, buf); + array_unshift($this->items, $entry); + return 0; + } catch (Exception $e) { + return -1; + } + } + + //---------------------------------------------------------------------- + public function calcParity() + { + $parity = 0; + + foreach($this->items as $item) { + if($item->mode != QR_MODE_STRUCTURE) { + for($i=$item->size-1; $i>=0; $i--) { + $parity ^= $item->data[$i]; + } + } + } + + return $parity; + } + + //---------------------------------------------------------------------- + public static function checkModeNum($size, $data) + { + for($i=0; $i<$size; $i++) { + if((ord($data[$i]) < ord('0')) || (ord($data[$i]) > ord('9'))){ + return false; + } + } + + return true; + } + + //---------------------------------------------------------------------- + public static function estimateBitsModeNum($size) + { + $w = (int)$size / 3; + $bits = $w * 10; + + switch($size - $w * 3) { + case 1: + $bits += 4; + break; + case 2: + $bits += 7; + break; + default: + break; + } + + return $bits; + } + + //---------------------------------------------------------------------- + public static $anTable = array( + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + 36, -1, -1, -1, 37, 38, -1, -1, -1, -1, 39, 40, -1, 41, 42, 43, + 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 44, -1, -1, -1, -1, -1, + -1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, + 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, + -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 + ); + + //---------------------------------------------------------------------- + public static function lookAnTable($c) + { + return (($c > 127)?-1:self::$anTable[$c]); + } + + //---------------------------------------------------------------------- + public static function checkModeAn($size, $data) + { + for($i=0; $i<$size; $i++) { + if (self::lookAnTable(ord($data[$i])) == -1) { + return false; + } + } + + return true; + } + + //---------------------------------------------------------------------- + public static function estimateBitsModeAn($size) + { + $w = (int)($size / 2); + $bits = $w * 11; + + if($size & 1) { + $bits += 6; + } + + return $bits; + } + + //---------------------------------------------------------------------- + public static function estimateBitsMode8($size) + { + return $size * 8; + } + + //---------------------------------------------------------------------- + public function estimateBitsModeKanji($size) + { + return (int)(($size / 2) * 13); + } + + //---------------------------------------------------------------------- + public static function checkModeKanji($size, $data) + { + if($size & 1) + return false; + + for($i=0; $i<$size; $i+=2) { + $val = (ord($data[$i]) << 8) | ord($data[$i+1]); + if( $val < 0x8140 + || ($val > 0x9ffc && $val < 0xe040) + || $val > 0xebbf) { + return false; + } + } + + return true; + } + + /*********************************************************************** + * Validation + **********************************************************************/ + + public static function check($mode, $size, $data) + { + if($size <= 0) + return false; + + switch($mode) { + case QR_MODE_NUM: return self::checkModeNum($size, $data); break; + case QR_MODE_AN: return self::checkModeAn($size, $data); break; + case QR_MODE_KANJI: return self::checkModeKanji($size, $data); break; + case QR_MODE_8: return true; break; + case QR_MODE_STRUCTURE: return true; break; + + default: + break; + } + + return false; + } + + + //---------------------------------------------------------------------- + public function estimateBitStreamSize($version) + { + $bits = 0; + + foreach($this->items as $item) { + $bits += $item->estimateBitStreamSizeOfEntry($version); + } + + return $bits; + } + + //---------------------------------------------------------------------- + public function estimateVersion() + { + $version = 0; + $prev = 0; + do { + $prev = $version; + $bits = $this->estimateBitStreamSize($prev); + $version = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if ($version < 0) { + return -1; + } + } while ($version > $prev); + + return $version; + } + + //---------------------------------------------------------------------- + public static function lengthOfCode($mode, $version, $bits) + { + $payload = $bits - 4 - QRspec::lengthIndicator($mode, $version); + switch($mode) { + case QR_MODE_NUM: + $chunks = (int)($payload / 10); + $remain = $payload - $chunks * 10; + $size = $chunks * 3; + if($remain >= 7) { + $size += 2; + } else if($remain >= 4) { + $size += 1; + } + break; + case QR_MODE_AN: + $chunks = (int)($payload / 11); + $remain = $payload - $chunks * 11; + $size = $chunks * 2; + if($remain >= 6) + $size++; + break; + case QR_MODE_8: + $size = (int)($payload / 8); + break; + case QR_MODE_KANJI: + $size = (int)(($payload / 13) * 2); + break; + case QR_MODE_STRUCTURE: + $size = (int)($payload / 8); + break; + default: + $size = 0; + break; + } + + $maxsize = QRspec::maximumWords($mode, $version); + if($size < 0) $size = 0; + if($size > $maxsize) $size = $maxsize; + + return $size; + } + + //---------------------------------------------------------------------- + public function createBitStream() + { + $total = 0; + + foreach($this->items as $item) { + $bits = $item->encodeBitStream($this->version); + + if($bits < 0) + return -1; + + $total += $bits; + } + + return $total; + } + + //---------------------------------------------------------------------- + public function convertData() + { + $ver = $this->estimateVersion(); + if($ver > $this->getVersion()) { + $this->setVersion($ver); + } + + for(;;) { + $bits = $this->createBitStream(); + + if($bits < 0) + return -1; + + $ver = QRspec::getMinimumVersion((int)(($bits + 7) / 8), $this->level); + if($ver < 0) { + throw new Exception('WRONG VERSION'); + return -1; + } else if($ver > $this->getVersion()) { + $this->setVersion($ver); + } else { + break; + } + } + + return 0; + } + + //---------------------------------------------------------------------- + public function appendPaddingBit(&$bstream) + { + $bits = $bstream->size(); + $maxwords = QRspec::getDataLength($this->version, $this->level); + $maxbits = $maxwords * 8; + + if ($maxbits == $bits) { + return 0; + } + + if ($maxbits - $bits < 5) { + return $bstream->appendNum($maxbits - $bits, 0); + } + + $bits += 4; + $words = (int)(($bits + 7) / 8); + + $padding = new QRbitstream(); + $ret = $padding->appendNum($words * 8 - $bits + 4, 0); + + if($ret < 0) + return $ret; + + $padlen = $maxwords - $words; + + if($padlen > 0) { + + $padbuf = array(); + for($i=0; $i<$padlen; $i++) { + $padbuf[$i] = ($i&1)?0x11:0xec; + } + + $ret = $padding->appendBytes($padlen, $padbuf); + + if($ret < 0) + return $ret; + + } + + $ret = $bstream->append($padding); + + return $ret; + } + + //---------------------------------------------------------------------- + public function mergeBitStream() + { + if($this->convertData() < 0) { + return null; + } + + $bstream = new QRbitstream(); + + foreach($this->items as $item) { + $ret = $bstream->append($item->bstream); + if($ret < 0) { + return null; + } + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function getBitStream() + { + + $bstream = $this->mergeBitStream(); + + if($bstream == null) { + return null; + } + + $ret = $this->appendPaddingBit($bstream); + if($ret < 0) { + return null; + } + + return $bstream; + } + + //---------------------------------------------------------------------- + public function getByteStream() + { + $bstream = $this->getBitStream(); + if($bstream == null) { + return null; + } + + return $bstream->toByte(); + } + } + + + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrlib.php b/src-backup/includes/phpqrcode/qrlib.php new file mode 100644 index 0000000..d55c4af --- /dev/null +++ b/src-backup/includes/phpqrcode/qrlib.php @@ -0,0 +1,43 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + $QR_BASEDIR = dirname(__FILE__).DIRECTORY_SEPARATOR; + + // Required libs + + include $QR_BASEDIR."qrconst.php"; + include $QR_BASEDIR."qrconfig.php"; + include $QR_BASEDIR."qrtools.php"; + include $QR_BASEDIR."qrspec.php"; + include $QR_BASEDIR."qrimage.php"; + include $QR_BASEDIR."qrinput.php"; + include $QR_BASEDIR."qrbitstream.php"; + include $QR_BASEDIR."qrsplit.php"; + include $QR_BASEDIR."qrrscode.php"; + include $QR_BASEDIR."qrmask.php"; + include $QR_BASEDIR."qrencode.php"; + diff --git a/src-backup/includes/phpqrcode/qrmask.php b/src-backup/includes/phpqrcode/qrmask.php new file mode 100644 index 0000000..b14d7ae --- /dev/null +++ b/src-backup/includes/phpqrcode/qrmask.php @@ -0,0 +1,328 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('N1', 3); + define('N2', 3); + define('N3', 40); + define('N4', 10); + + class QRmask { + + public $runLength = array(); + + //---------------------------------------------------------------------- + public function __construct() + { + $this->runLength = array_fill(0, QRSPEC_WIDTH_MAX + 1, 0); + } + + //---------------------------------------------------------------------- + public function writeFormatInformation($width, &$frame, $mask, $level) + { + $blacks = 0; + $format = QRspec::getFormatInfo($mask, $level); + + for($i=0; $i<8; $i++) { + if($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + + $frame[8][$width - 1 - $i] = chr($v); + if($i < 6) { + $frame[$i][8] = chr($v); + } else { + $frame[$i + 1][8] = chr($v); + } + $format = $format >> 1; + } + + for($i=0; $i<7; $i++) { + if($format & 1) { + $blacks += 2; + $v = 0x85; + } else { + $v = 0x84; + } + + $frame[$width - 7 + $i][8] = chr($v); + if($i == 0) { + $frame[8][7] = chr($v); + } else { + $frame[8][6 - $i] = chr($v); + } + + $format = $format >> 1; + } + + return $blacks; + } + + //---------------------------------------------------------------------- + public function mask0($x, $y) { return ($x+$y)&1; } + public function mask1($x, $y) { return ($y&1); } + public function mask2($x, $y) { return ($x%3); } + public function mask3($x, $y) { return ($x+$y)%3; } + public function mask4($x, $y) { return (((int)($y/2))+((int)($x/3)))&1; } + public function mask5($x, $y) { return (($x*$y)&1)+($x*$y)%3; } + public function mask6($x, $y) { return ((($x*$y)&1)+($x*$y)%3)&1; } + public function mask7($x, $y) { return ((($x*$y)%3)+(($x+$y)&1))&1; } + + //---------------------------------------------------------------------- + private function generateMaskNo($maskNo, $width, $frame) + { + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + + for($y=0; $y<$width; $y++) { + for($x=0; $x<$width; $x++) { + if(ord($frame[$y][$x]) & 0x80) { + $bitMask[$y][$x] = 0; + } else { + $maskFunc = call_user_func(array($this, 'mask'.$maskNo), $x, $y); + $bitMask[$y][$x] = ($maskFunc == 0)?1:0; + } + + } + } + + return $bitMask; + } + + //---------------------------------------------------------------------- + public static function serial($bitFrame) + { + $codeArr = array(); + + foreach ($bitFrame as $line) + $codeArr[] = join('', $line); + + return gzcompress(join("\n", $codeArr), 9); + } + + //---------------------------------------------------------------------- + public static function unserial($code) + { + $codeArr = array(); + + $codeLines = explode("\n", gzuncompress($code)); + foreach ($codeLines as $line) + $codeArr[] = str_split($line); + + return $codeArr; + } + + //---------------------------------------------------------------------- + public function makeMaskNo($maskNo, $width, $s, &$d, $maskGenOnly = false) + { + $b = 0; + $bitMask = array(); + + $fileName = QR_CACHE_DIR.'mask_'.$maskNo.DIRECTORY_SEPARATOR.'mask_'.$width.'_'.$maskNo.'.dat'; + + if (QR_CACHEABLE) { + if (file_exists($fileName)) { + $bitMask = self::unserial(file_get_contents($fileName)); + } else { + $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); + if (!file_exists(QR_CACHE_DIR.'mask_'.$maskNo)) + mkdir(QR_CACHE_DIR.'mask_'.$maskNo); + file_put_contents($fileName, self::serial($bitMask)); + } + } else { + $bitMask = $this->generateMaskNo($maskNo, $width, $s, $d); + } + + if ($maskGenOnly) + return; + + $d = $s; + + for($y=0; $y<$width; $y++) { + for($x=0; $x<$width; $x++) { + if($bitMask[$y][$x] == 1) { + $d[$y][$x] = chr(ord($s[$y][$x]) ^ (int)$bitMask[$y][$x]); + } + $b += (int)(ord($d[$y][$x]) & 1); + } + } + + return $b; + } + + //---------------------------------------------------------------------- + public function makeMask($width, $frame, $maskNo, $level) + { + $masked = array_fill(0, $width, str_repeat("\0", $width)); + $this->makeMaskNo($maskNo, $width, $frame, $masked); + $this->writeFormatInformation($width, $masked, $maskNo, $level); + + return $masked; + } + + //---------------------------------------------------------------------- + public function calcN1N3($length) + { + $demerit = 0; + + for($i=0; $i<$length; $i++) { + + if($this->runLength[$i] >= 5) { + $demerit += (N1 + ($this->runLength[$i] - 5)); + } + if($i & 1) { + if(($i >= 3) && ($i < ($length-2)) && ($this->runLength[$i] % 3 == 0)) { + $fact = (int)($this->runLength[$i] / 3); + if(($this->runLength[$i-2] == $fact) && + ($this->runLength[$i-1] == $fact) && + ($this->runLength[$i+1] == $fact) && + ($this->runLength[$i+2] == $fact)) { + if(($this->runLength[$i-3] < 0) || ($this->runLength[$i-3] >= (4 * $fact))) { + $demerit += N3; + } else if((($i+3) >= $length) || ($this->runLength[$i+3] >= (4 * $fact))) { + $demerit += N3; + } + } + } + } + } + return $demerit; + } + + //---------------------------------------------------------------------- + public function evaluateSymbol($width, $frame) + { + $head = 0; + $demerit = 0; + + for($y=0; $y<$width; $y++) { + $head = 0; + $this->runLength[0] = 1; + + $frameY = $frame[$y]; + + if ($y>0) + $frameYM = $frame[$y-1]; + + for($x=0; $x<$width; $x++) { + if(($x > 0) && ($y > 0)) { + $b22 = ord($frameY[$x]) & ord($frameY[$x-1]) & ord($frameYM[$x]) & ord($frameYM[$x-1]); + $w22 = ord($frameY[$x]) | ord($frameY[$x-1]) | ord($frameYM[$x]) | ord($frameYM[$x-1]); + + if(($b22 | ($w22 ^ 1))&1) { + $demerit += N2; + } + } + if(($x == 0) && (ord($frameY[$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } else if($x > 0) { + if((ord($frameY[$x]) ^ ord($frameY[$x-1])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + + $demerit += $this->calcN1N3($head+1); + } + + for($x=0; $x<$width; $x++) { + $head = 0; + $this->runLength[0] = 1; + + for($y=0; $y<$width; $y++) { + if($y == 0 && (ord($frame[$y][$x]) & 1)) { + $this->runLength[0] = -1; + $head = 1; + $this->runLength[$head] = 1; + } else if($y > 0) { + if((ord($frame[$y][$x]) ^ ord($frame[$y-1][$x])) & 1) { + $head++; + $this->runLength[$head] = 1; + } else { + $this->runLength[$head]++; + } + } + } + + $demerit += $this->calcN1N3($head+1); + } + + return $demerit; + } + + + //---------------------------------------------------------------------- + public function mask($width, $frame, $level) + { + $minDemerit = PHP_INT_MAX; + $bestMaskNum = 0; + $bestMask = array(); + + $checked_masks = array(0,1,2,3,4,5,6,7); + + if (QR_FIND_FROM_RANDOM !== false) { + + $howManuOut = 8-(QR_FIND_FROM_RANDOM % 9); + for ($i = 0; $i < $howManuOut; $i++) { + $remPos = rand (0, count($checked_masks)-1); + unset($checked_masks[$remPos]); + $checked_masks = array_values($checked_masks); + } + + } + + $bestMask = $frame; + + foreach($checked_masks as $i) { + $mask = array_fill(0, $width, str_repeat("\0", $width)); + + $demerit = 0; + $blacks = 0; + $blacks = $this->makeMaskNo($i, $width, $frame, $mask); + $blacks += $this->writeFormatInformation($width, $mask, $i, $level); + $blacks = (int)(100 * $blacks / ($width * $width)); + $demerit = (int)((int)(abs($blacks - 50) / 5) * N4); + $demerit += $this->evaluateSymbol($width, $mask); + + if($demerit < $minDemerit) { + $minDemerit = $demerit; + $bestMask = $mask; + $bestMaskNum = $i; + } + } + + return $bestMask; + } + + //---------------------------------------------------------------------- + } diff --git a/src-backup/includes/phpqrcode/qrrscode.php b/src-backup/includes/phpqrcode/qrrscode.php new file mode 100644 index 0000000..591129a --- /dev/null +++ b/src-backup/includes/phpqrcode/qrrscode.php @@ -0,0 +1,210 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRrsItem { + + public $mm; // Bits per symbol + public $nn; // Symbols per block (= (1<= $this->nn) { + $x -= $this->nn; + $x = ($x >> $this->mm) + ($x & $this->nn); + } + + return $x; + } + + //---------------------------------------------------------------------- + public static function init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) + { + // Common code for intializing a Reed-Solomon control block (char or int symbols) + // Copyright 2004 Phil Karn, KA9Q + // May be used under the terms of the GNU Lesser General Public License (LGPL) + + $rs = null; + + // Check parameter ranges + if($symsize < 0 || $symsize > 8) return $rs; + if($fcr < 0 || $fcr >= (1<<$symsize)) return $rs; + if($prim <= 0 || $prim >= (1<<$symsize)) return $rs; + if($nroots < 0 || $nroots >= (1<<$symsize)) return $rs; // Can't have more roots than symbol values! + if($pad < 0 || $pad >= ((1<<$symsize) -1 - $nroots)) return $rs; // Too much padding + + $rs = new QRrsItem(); + $rs->mm = $symsize; + $rs->nn = (1<<$symsize)-1; + $rs->pad = $pad; + + $rs->alpha_to = array_fill(0, $rs->nn+1, 0); + $rs->index_of = array_fill(0, $rs->nn+1, 0); + + // PHP style macro replacement ;) + $NN =& $rs->nn; + $A0 =& $NN; + + // Generate Galois field lookup tables + $rs->index_of[0] = $A0; // log(zero) = -inf + $rs->alpha_to[$A0] = 0; // alpha**-inf = 0 + $sr = 1; + + for($i=0; $i<$rs->nn; $i++) { + $rs->index_of[$sr] = $i; + $rs->alpha_to[$i] = $sr; + $sr <<= 1; + if($sr & (1<<$symsize)) { + $sr ^= $gfpoly; + } + $sr &= $rs->nn; + } + + if($sr != 1){ + // field generator polynomial is not primitive! + $rs = NULL; + return $rs; + } + + /* Form RS code generator polynomial from its roots */ + $rs->genpoly = array_fill(0, $nroots+1, 0); + + $rs->fcr = $fcr; + $rs->prim = $prim; + $rs->nroots = $nroots; + $rs->gfpoly = $gfpoly; + + /* Find prim-th root of 1, used in decoding */ + for($iprim=1;($iprim % $prim) != 0;$iprim += $rs->nn) + ; // intentional empty-body loop! + + $rs->iprim = (int)($iprim / $prim); + $rs->genpoly[0] = 1; + + for ($i = 0,$root=$fcr*$prim; $i < $nroots; $i++, $root += $prim) { + $rs->genpoly[$i+1] = 1; + + // Multiply rs->genpoly[] by @**(root + x) + for ($j = $i; $j > 0; $j--) { + if ($rs->genpoly[$j] != 0) { + $rs->genpoly[$j] = $rs->genpoly[$j-1] ^ $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[$j]] + $root)]; + } else { + $rs->genpoly[$j] = $rs->genpoly[$j-1]; + } + } + // rs->genpoly[0] can never be zero + $rs->genpoly[0] = $rs->alpha_to[$rs->modnn($rs->index_of[$rs->genpoly[0]] + $root)]; + } + + // convert rs->genpoly[] to index form for quicker encoding + for ($i = 0; $i <= $nroots; $i++) + $rs->genpoly[$i] = $rs->index_of[$rs->genpoly[$i]]; + + return $rs; + } + + //---------------------------------------------------------------------- + public function encode_rs_char($data, &$parity) + { + $MM =& $this->mm; + $NN =& $this->nn; + $ALPHA_TO =& $this->alpha_to; + $INDEX_OF =& $this->index_of; + $GENPOLY =& $this->genpoly; + $NROOTS =& $this->nroots; + $FCR =& $this->fcr; + $PRIM =& $this->prim; + $IPRIM =& $this->iprim; + $PAD =& $this->pad; + $A0 =& $NN; + + $parity = array_fill(0, $NROOTS, 0); + + for($i=0; $i< ($NN-$NROOTS-$PAD); $i++) { + + $feedback = $INDEX_OF[$data[$i] ^ $parity[0]]; + if($feedback != $A0) { + // feedback term is non-zero + + // This line is unnecessary when GENPOLY[NROOTS] is unity, as it must + // always be for the polynomials constructed by init_rs() + $feedback = $this->modnn($NN - $GENPOLY[$NROOTS] + $feedback); + + for($j=1;$j<$NROOTS;$j++) { + $parity[$j] ^= $ALPHA_TO[$this->modnn($feedback + $GENPOLY[$NROOTS-$j])]; + } + } + + // Shift + array_shift($parity); + if($feedback != $A0) { + array_push($parity, $ALPHA_TO[$this->modnn($feedback + $GENPOLY[0])]); + } else { + array_push($parity, 0); + } + } + } + } + + //########################################################################## + + class QRrs { + + public static $items = array(); + + //---------------------------------------------------------------------- + public static function init_rs($symsize, $gfpoly, $fcr, $prim, $nroots, $pad) + { + foreach(self::$items as $rs) { + if($rs->pad != $pad) continue; + if($rs->nroots != $nroots) continue; + if($rs->mm != $symsize) continue; + if($rs->gfpoly != $gfpoly) continue; + if($rs->fcr != $fcr) continue; + if($rs->prim != $prim) continue; + + return $rs; + } + + $rs = QRrsItem::init_rs_char($symsize, $gfpoly, $fcr, $prim, $nroots, $pad); + array_unshift(self::$items, $rs); + + return $rs; + } + } \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrspec.php b/src-backup/includes/phpqrcode/qrspec.php new file mode 100644 index 0000000..92aea0c --- /dev/null +++ b/src-backup/includes/phpqrcode/qrspec.php @@ -0,0 +1,592 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * The following data / specifications are taken from + * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) + * or + * "Automatic identification and data capture techniques -- + * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + define('QRSPEC_VERSION_MAX', 40); + define('QRSPEC_WIDTH_MAX', 177); + + define('QRCAP_WIDTH', 0); + define('QRCAP_WORDS', 1); + define('QRCAP_REMINDER', 2); + define('QRCAP_EC', 3); + + class QRspec { + + public static $capacity = array( + array( 0, 0, 0, array( 0, 0, 0, 0)), + array( 21, 26, 0, array( 7, 10, 13, 17)), // 1 + array( 25, 44, 7, array( 10, 16, 22, 28)), + array( 29, 70, 7, array( 15, 26, 36, 44)), + array( 33, 100, 7, array( 20, 36, 52, 64)), + array( 37, 134, 7, array( 26, 48, 72, 88)), // 5 + array( 41, 172, 7, array( 36, 64, 96, 112)), + array( 45, 196, 0, array( 40, 72, 108, 130)), + array( 49, 242, 0, array( 48, 88, 132, 156)), + array( 53, 292, 0, array( 60, 110, 160, 192)), + array( 57, 346, 0, array( 72, 130, 192, 224)), //10 + array( 61, 404, 0, array( 80, 150, 224, 264)), + array( 65, 466, 0, array( 96, 176, 260, 308)), + array( 69, 532, 0, array( 104, 198, 288, 352)), + array( 73, 581, 3, array( 120, 216, 320, 384)), + array( 77, 655, 3, array( 132, 240, 360, 432)), //15 + array( 81, 733, 3, array( 144, 280, 408, 480)), + array( 85, 815, 3, array( 168, 308, 448, 532)), + array( 89, 901, 3, array( 180, 338, 504, 588)), + array( 93, 991, 3, array( 196, 364, 546, 650)), + array( 97, 1085, 3, array( 224, 416, 600, 700)), //20 + array(101, 1156, 4, array( 224, 442, 644, 750)), + array(105, 1258, 4, array( 252, 476, 690, 816)), + array(109, 1364, 4, array( 270, 504, 750, 900)), + array(113, 1474, 4, array( 300, 560, 810, 960)), + array(117, 1588, 4, array( 312, 588, 870, 1050)), //25 + array(121, 1706, 4, array( 336, 644, 952, 1110)), + array(125, 1828, 4, array( 360, 700, 1020, 1200)), + array(129, 1921, 3, array( 390, 728, 1050, 1260)), + array(133, 2051, 3, array( 420, 784, 1140, 1350)), + array(137, 2185, 3, array( 450, 812, 1200, 1440)), //30 + array(141, 2323, 3, array( 480, 868, 1290, 1530)), + array(145, 2465, 3, array( 510, 924, 1350, 1620)), + array(149, 2611, 3, array( 540, 980, 1440, 1710)), + array(153, 2761, 3, array( 570, 1036, 1530, 1800)), + array(157, 2876, 0, array( 570, 1064, 1590, 1890)), //35 + array(161, 3034, 0, array( 600, 1120, 1680, 1980)), + array(165, 3196, 0, array( 630, 1204, 1770, 2100)), + array(169, 3362, 0, array( 660, 1260, 1860, 2220)), + array(173, 3532, 0, array( 720, 1316, 1950, 2310)), + array(177, 3706, 0, array( 750, 1372, 2040, 2430)) //40 + ); + + //---------------------------------------------------------------------- + public static function getDataLength($version, $level) + { + return self::$capacity[$version][QRCAP_WORDS] - self::$capacity[$version][QRCAP_EC][$level]; + } + + //---------------------------------------------------------------------- + public static function getECCLength($version, $level) + { + return self::$capacity[$version][QRCAP_EC][$level]; + } + + //---------------------------------------------------------------------- + public static function getWidth($version) + { + return self::$capacity[$version][QRCAP_WIDTH]; + } + + //---------------------------------------------------------------------- + public static function getRemainder($version) + { + return self::$capacity[$version][QRCAP_REMINDER]; + } + + //---------------------------------------------------------------------- + public static function getMinimumVersion($size, $level) + { + + for($i=1; $i<= QRSPEC_VERSION_MAX; $i++) { + $words = self::$capacity[$i][QRCAP_WORDS] - self::$capacity[$i][QRCAP_EC][$level]; + if($words >= $size) + return $i; + } + + return -1; + } + + //###################################################################### + + public static $lengthTableBits = array( + array(10, 12, 14), + array( 9, 11, 13), + array( 8, 16, 16), + array( 8, 10, 12) + ); + + //---------------------------------------------------------------------- + public static function lengthIndicator($mode, $version) + { + if ($mode == QR_MODE_STRUCTURE) + return 0; + + if ($version <= 9) { + $l = 0; + } else if ($version <= 26) { + $l = 1; + } else { + $l = 2; + } + + return self::$lengthTableBits[$mode][$l]; + } + + //---------------------------------------------------------------------- + public static function maximumWords($mode, $version) + { + if($mode == QR_MODE_STRUCTURE) + return 3; + + if($version <= 9) { + $l = 0; + } else if($version <= 26) { + $l = 1; + } else { + $l = 2; + } + + $bits = self::$lengthTableBits[$mode][$l]; + $words = (1 << $bits) - 1; + + if($mode == QR_MODE_KANJI) { + $words *= 2; // the number of bytes is required + } + + return $words; + } + + // Error correction code ----------------------------------------------- + // Table of the error correction code (Reed-Solomon block) + // See Table 12-16 (pp.30-36), JIS X0510:2004. + + public static $eccTable = array( + array(array( 0, 0), array( 0, 0), array( 0, 0), array( 0, 0)), + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), // 1 + array(array( 1, 0), array( 1, 0), array( 1, 0), array( 1, 0)), + array(array( 1, 0), array( 1, 0), array( 2, 0), array( 2, 0)), + array(array( 1, 0), array( 2, 0), array( 2, 0), array( 4, 0)), + array(array( 1, 0), array( 2, 0), array( 2, 2), array( 2, 2)), // 5 + array(array( 2, 0), array( 4, 0), array( 4, 0), array( 4, 0)), + array(array( 2, 0), array( 4, 0), array( 2, 4), array( 4, 1)), + array(array( 2, 0), array( 2, 2), array( 4, 2), array( 4, 2)), + array(array( 2, 0), array( 3, 2), array( 4, 4), array( 4, 4)), + array(array( 2, 2), array( 4, 1), array( 6, 2), array( 6, 2)), //10 + array(array( 4, 0), array( 1, 4), array( 4, 4), array( 3, 8)), + array(array( 2, 2), array( 6, 2), array( 4, 6), array( 7, 4)), + array(array( 4, 0), array( 8, 1), array( 8, 4), array(12, 4)), + array(array( 3, 1), array( 4, 5), array(11, 5), array(11, 5)), + array(array( 5, 1), array( 5, 5), array( 5, 7), array(11, 7)), //15 + array(array( 5, 1), array( 7, 3), array(15, 2), array( 3, 13)), + array(array( 1, 5), array(10, 1), array( 1, 15), array( 2, 17)), + array(array( 5, 1), array( 9, 4), array(17, 1), array( 2, 19)), + array(array( 3, 4), array( 3, 11), array(17, 4), array( 9, 16)), + array(array( 3, 5), array( 3, 13), array(15, 5), array(15, 10)), //20 + array(array( 4, 4), array(17, 0), array(17, 6), array(19, 6)), + array(array( 2, 7), array(17, 0), array( 7, 16), array(34, 0)), + array(array( 4, 5), array( 4, 14), array(11, 14), array(16, 14)), + array(array( 6, 4), array( 6, 14), array(11, 16), array(30, 2)), + array(array( 8, 4), array( 8, 13), array( 7, 22), array(22, 13)), //25 + array(array(10, 2), array(19, 4), array(28, 6), array(33, 4)), + array(array( 8, 4), array(22, 3), array( 8, 26), array(12, 28)), + array(array( 3, 10), array( 3, 23), array( 4, 31), array(11, 31)), + array(array( 7, 7), array(21, 7), array( 1, 37), array(19, 26)), + array(array( 5, 10), array(19, 10), array(15, 25), array(23, 25)), //30 + array(array(13, 3), array( 2, 29), array(42, 1), array(23, 28)), + array(array(17, 0), array(10, 23), array(10, 35), array(19, 35)), + array(array(17, 1), array(14, 21), array(29, 19), array(11, 46)), + array(array(13, 6), array(14, 23), array(44, 7), array(59, 1)), + array(array(12, 7), array(12, 26), array(39, 14), array(22, 41)), //35 + array(array( 6, 14), array( 6, 34), array(46, 10), array( 2, 64)), + array(array(17, 4), array(29, 14), array(49, 10), array(24, 46)), + array(array( 4, 18), array(13, 32), array(48, 14), array(42, 32)), + array(array(20, 4), array(40, 7), array(43, 22), array(10, 67)), + array(array(19, 6), array(18, 31), array(34, 34), array(20, 61)),//40 + ); + + //---------------------------------------------------------------------- + // CACHEABLE!!! + + public static function getEccSpec($version, $level, array &$spec) + { + if (count($spec) < 5) { + $spec = array(0,0,0,0,0); + } + + $b1 = self::$eccTable[$version][$level][0]; + $b2 = self::$eccTable[$version][$level][1]; + $data = self::getDataLength($version, $level); + $ecc = self::getECCLength($version, $level); + + if($b2 == 0) { + $spec[0] = $b1; + $spec[1] = (int)($data / $b1); + $spec[2] = (int)($ecc / $b1); + $spec[3] = 0; + $spec[4] = 0; + } else { + $spec[0] = $b1; + $spec[1] = (int)($data / ($b1 + $b2)); + $spec[2] = (int)($ecc / ($b1 + $b2)); + $spec[3] = $b2; + $spec[4] = $spec[1] + 1; + } + } + + // Alignment pattern --------------------------------------------------- + + // Positions of alignment patterns. + // This array includes only the second and the third position of the + // alignment patterns. Rest of them can be calculated from the distance + // between them. + + // See Table 1 in Appendix E (pp.71) of JIS X0510:2004. + + public static $alignmentPattern = array( + array( 0, 0), + array( 0, 0), array(18, 0), array(22, 0), array(26, 0), array(30, 0), // 1- 5 + array(34, 0), array(22, 38), array(24, 42), array(26, 46), array(28, 50), // 6-10 + array(30, 54), array(32, 58), array(34, 62), array(26, 46), array(26, 48), //11-15 + array(26, 50), array(30, 54), array(30, 56), array(30, 58), array(34, 62), //16-20 + array(28, 50), array(26, 50), array(30, 54), array(28, 54), array(32, 58), //21-25 + array(30, 58), array(34, 62), array(26, 50), array(30, 54), array(26, 52), //26-30 + array(30, 56), array(34, 60), array(30, 58), array(34, 62), array(30, 54), //31-35 + array(24, 50), array(28, 54), array(32, 58), array(26, 54), array(30, 58), //35-40 + ); + + + /** -------------------------------------------------------------------- + * Put an alignment marker. + * @param frame + * @param width + * @param ox,oy center coordinate of the pattern + */ + public static function putAlignmentMarker(array &$frame, $ox, $oy) + { + $finder = array( + "\xa1\xa1\xa1\xa1\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa0\xa1\xa0\xa1", + "\xa1\xa0\xa0\xa0\xa1", + "\xa1\xa1\xa1\xa1\xa1" + ); + + $yStart = $oy-2; + $xStart = $ox-2; + + for($y=0; $y<5; $y++) { + QRstr::set($frame, $xStart, $yStart+$y, $finder[$y]); + } + } + + //---------------------------------------------------------------------- + public static function putAlignmentPattern($version, &$frame, $width) + { + if($version < 2) + return; + + $d = self::$alignmentPattern[$version][1] - self::$alignmentPattern[$version][0]; + if($d < 0) { + $w = 2; + } else { + $w = (int)(($width - self::$alignmentPattern[$version][0]) / $d + 2); + } + + if($w * $w - 3 == 1) { + $x = self::$alignmentPattern[$version][0]; + $y = self::$alignmentPattern[$version][0]; + self::putAlignmentMarker($frame, $x, $y); + return; + } + + $cx = self::$alignmentPattern[$version][0]; + for($x=1; $x<$w - 1; $x++) { + self::putAlignmentMarker($frame, 6, $cx); + self::putAlignmentMarker($frame, $cx, 6); + $cx += $d; + } + + $cy = self::$alignmentPattern[$version][0]; + for($y=0; $y<$w-1; $y++) { + $cx = self::$alignmentPattern[$version][0]; + for($x=0; $x<$w-1; $x++) { + self::putAlignmentMarker($frame, $cx, $cy); + $cx += $d; + } + $cy += $d; + } + } + + // Version information pattern ----------------------------------------- + + // Version information pattern (BCH coded). + // See Table 1 in Appendix D (pp.68) of JIS X0510:2004. + + // size: [QRSPEC_VERSION_MAX - 6] + + public static $versionPattern = array( + 0x07c94, 0x085bc, 0x09a99, 0x0a4d3, 0x0bbf6, 0x0c762, 0x0d847, 0x0e60d, + 0x0f928, 0x10b78, 0x1145d, 0x12a17, 0x13532, 0x149a6, 0x15683, 0x168c9, + 0x177ec, 0x18ec4, 0x191e1, 0x1afab, 0x1b08e, 0x1cc1a, 0x1d33f, 0x1ed75, + 0x1f250, 0x209d5, 0x216f0, 0x228ba, 0x2379f, 0x24b0b, 0x2542e, 0x26a64, + 0x27541, 0x28c69 + ); + + //---------------------------------------------------------------------- + public static function getVersionPattern($version) + { + if($version < 7 || $version > QRSPEC_VERSION_MAX) + return 0; + + return self::$versionPattern[$version -7]; + } + + // Format information -------------------------------------------------- + // See calcFormatInfo in tests/test_qrspec.c (orginal qrencode c lib) + + public static $formatInfo = array( + array(0x77c4, 0x72f3, 0x7daa, 0x789d, 0x662f, 0x6318, 0x6c41, 0x6976), + array(0x5412, 0x5125, 0x5e7c, 0x5b4b, 0x45f9, 0x40ce, 0x4f97, 0x4aa0), + array(0x355f, 0x3068, 0x3f31, 0x3a06, 0x24b4, 0x2183, 0x2eda, 0x2bed), + array(0x1689, 0x13be, 0x1ce7, 0x19d0, 0x0762, 0x0255, 0x0d0c, 0x083b) + ); + + public static function getFormatInfo($mask, $level) + { + if($mask < 0 || $mask > 7) + return 0; + + if($level < 0 || $level > 3) + return 0; + + return self::$formatInfo[$level][$mask]; + } + + // Frame --------------------------------------------------------------- + // Cache of initial frames. + + public static $frames = array(); + + /** -------------------------------------------------------------------- + * Put a finder pattern. + * @param frame + * @param width + * @param ox,oy upper-left coordinate of the pattern + */ + public static function putFinderPattern(&$frame, $ox, $oy) + { + $finder = array( + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc1\xc1\xc1\xc0\xc1", + "\xc1\xc0\xc0\xc0\xc0\xc0\xc1", + "\xc1\xc1\xc1\xc1\xc1\xc1\xc1" + ); + + for($y=0; $y<7; $y++) { + QRstr::set($frame, $ox, $oy+$y, $finder[$y]); + } + } + + //---------------------------------------------------------------------- + public static function createFrame($version) + { + $width = self::$capacity[$version][QRCAP_WIDTH]; + $frameLine = str_repeat ("\0", $width); + $frame = array_fill(0, $width, $frameLine); + + // Finder pattern + self::putFinderPattern($frame, 0, 0); + self::putFinderPattern($frame, $width - 7, 0); + self::putFinderPattern($frame, 0, $width - 7); + + // Separator + $yOffset = $width - 7; + + for($y=0; $y<7; $y++) { + $frame[$y][7] = "\xc0"; + $frame[$y][$width - 8] = "\xc0"; + $frame[$yOffset][7] = "\xc0"; + $yOffset++; + } + + $setPattern = str_repeat("\xc0", 8); + + QRstr::set($frame, 0, 7, $setPattern); + QRstr::set($frame, $width-8, 7, $setPattern); + QRstr::set($frame, 0, $width - 8, $setPattern); + + // Format info + $setPattern = str_repeat("\x84", 9); + QRstr::set($frame, 0, 8, $setPattern); + QRstr::set($frame, $width - 8, 8, $setPattern, 8); + + $yOffset = $width - 8; + + for($y=0; $y<8; $y++,$yOffset++) { + $frame[$y][8] = "\x84"; + $frame[$yOffset][8] = "\x84"; + } + + // Timing pattern + + for($i=1; $i<$width-15; $i++) { + $frame[6][7+$i] = chr(0x90 | ($i & 1)); + $frame[7+$i][6] = chr(0x90 | ($i & 1)); + } + + // Alignment pattern + self::putAlignmentPattern($version, $frame, $width); + + // Version information + if($version >= 7) { + $vinf = self::getVersionPattern($version); + + $v = $vinf; + + for($x=0; $x<6; $x++) { + for($y=0; $y<3; $y++) { + $frame[($width - 11)+$y][$x] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + + $v = $vinf; + for($y=0; $y<6; $y++) { + for($x=0; $x<3; $x++) { + $frame[$y][$x+($width - 11)] = chr(0x88 | ($v & 1)); + $v = $v >> 1; + } + } + } + + // and a little bit... + $frame[$width - 8][8] = "\x81"; + + return $frame; + } + + //---------------------------------------------------------------------- + public static function debug($frame, $binary_mode = false) + { + if ($binary_mode) { + + foreach ($frame as &$frameLine) { + $frameLine = join('  ', explode('0', $frameLine)); + $frameLine = join('██', explode('1', $frameLine)); + } + + ?> + +


        '; + echo join("
        ", $frame); + echo '






'; + + } else { + + foreach ($frame as &$frameLine) { + $frameLine = join(' ', explode("\xc0", $frameLine)); + $frameLine = join('', explode("\xc1", $frameLine)); + $frameLine = join(' ', explode("\xa0", $frameLine)); + $frameLine = join('', explode("\xa1", $frameLine)); + $frameLine = join('', explode("\x84", $frameLine)); //format 0 + $frameLine = join('', explode("\x85", $frameLine)); //format 1 + $frameLine = join('', explode("\x81", $frameLine)); //special bit + $frameLine = join(' ', explode("\x90", $frameLine)); //clock 0 + $frameLine = join('', explode("\x91", $frameLine)); //clock 1 + $frameLine = join(' ', explode("\x88", $frameLine)); //version + $frameLine = join('', explode("\x89", $frameLine)); //version + $frameLine = join('♦', explode("\x01", $frameLine)); + $frameLine = join('⋅', explode("\0", $frameLine)); + } + + ?> + + "; + echo join("
", $frame); + echo "
"; + + } + } + + //---------------------------------------------------------------------- + public static function serial($frame) + { + return gzcompress(join("\n", $frame), 9); + } + + //---------------------------------------------------------------------- + public static function unserial($code) + { + return explode("\n", gzuncompress($code)); + } + + //---------------------------------------------------------------------- + public static function newFrame($version) + { + if($version < 1 || $version > QRSPEC_VERSION_MAX) + return null; + + if(!isset(self::$frames[$version])) { + + $fileName = QR_CACHE_DIR.'frame_'.$version.'.dat'; + + if (QR_CACHEABLE) { + if (file_exists($fileName)) { + self::$frames[$version] = self::unserial(file_get_contents($fileName)); + } else { + self::$frames[$version] = self::createFrame($version); + file_put_contents($fileName, self::serial(self::$frames[$version])); + } + } else { + self::$frames[$version] = self::createFrame($version); + } + } + + if(is_null(self::$frames[$version])) + return null; + + return self::$frames[$version]; + } + + //---------------------------------------------------------------------- + public static function rsBlockNum($spec) { return $spec[0] + $spec[3]; } + public static function rsBlockNum1($spec) { return $spec[0]; } + public static function rsDataCodes1($spec) { return $spec[1]; } + public static function rsEccCodes1($spec) { return $spec[2]; } + public static function rsBlockNum2($spec) { return $spec[3]; } + public static function rsDataCodes2($spec) { return $spec[4]; } + public static function rsEccCodes2($spec) { return $spec[2]; } + public static function rsDataLength($spec) { return ($spec[0] * $spec[1]) + ($spec[3] * $spec[4]); } + public static function rsEccLength($spec) { return ($spec[0] + $spec[3]) * $spec[2]; } + + } \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrsplit.php b/src-backup/includes/phpqrcode/qrsplit.php new file mode 100644 index 0000000..d75b827 --- /dev/null +++ b/src-backup/includes/phpqrcode/qrsplit.php @@ -0,0 +1,311 @@ + + * + * PHP QR Code is distributed under LGPL 3 + * Copyright (C) 2010 Dominik Dzienia + * + * The following data / specifications are taken from + * "Two dimensional symbol -- QR-code -- Basic Specification" (JIS X0510:2004) + * or + * "Automatic identification and data capture techniques -- + * QR Code 2005 bar code symbology specification" (ISO/IEC 18004:2006) + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + class QRsplit { + + public $dataStr = ''; + public $input; + public $modeHint; + + //---------------------------------------------------------------------- + public function __construct($dataStr, $input, $modeHint) + { + $this->dataStr = $dataStr; + $this->input = $input; + $this->modeHint = $modeHint; + } + + //---------------------------------------------------------------------- + public static function isdigitat($str, $pos) + { + if ($pos >= strlen($str)) + return false; + + return ((ord($str[$pos]) >= ord('0'))&&(ord($str[$pos]) <= ord('9'))); + } + + //---------------------------------------------------------------------- + public static function isalnumat($str, $pos) + { + if ($pos >= strlen($str)) + return false; + + return (QRinput::lookAnTable(ord($str[$pos])) >= 0); + } + + //---------------------------------------------------------------------- + public function identifyMode($pos) + { + if ($pos >= strlen($this->dataStr)) + return QR_MODE_NUL; + + $c = $this->dataStr[$pos]; + + if(self::isdigitat($this->dataStr, $pos)) { + return QR_MODE_NUM; + } else if(self::isalnumat($this->dataStr, $pos)) { + return QR_MODE_AN; + } else if($this->modeHint == QR_MODE_KANJI) { + + if ($pos+1 < strlen($this->dataStr)) + { + $d = $this->dataStr[$pos+1]; + $word = (ord($c) << 8) | ord($d); + if(($word >= 0x8140 && $word <= 0x9ffc) || ($word >= 0xe040 && $word <= 0xebbf)) { + return QR_MODE_KANJI; + } + } + } + + return QR_MODE_8; + } + + //---------------------------------------------------------------------- + public function eatNum() + { + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 0; + while(self::isdigitat($this->dataStr, $p)) { + $p++; + } + + $run = $p; + $mode = $this->identifyMode($p); + + if($mode == QR_MODE_8) { + $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln + + QRinput::estimateBitsMode8(1) // + 4 + l8 + - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 + if($dif > 0) { + return $this->eat8(); + } + } + if($mode == QR_MODE_AN) { + $dif = QRinput::estimateBitsModeNum($run) + 4 + $ln + + QRinput::estimateBitsModeAn(1) // + 4 + la + - QRinput::estimateBitsModeAn($run + 1);// - 4 - la + if($dif > 0) { + return $this->eatAn(); + } + } + + $ret = $this->input->append(QR_MODE_NUM, $run, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eatAn() + { + $la = QRspec::lengthIndicator(QR_MODE_AN, $this->input->getVersion()); + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 0; + + while(self::isalnumat($this->dataStr, $p)) { + if(self::isdigitat($this->dataStr, $p)) { + $q = $p; + while(self::isdigitat($this->dataStr, $q)) { + $q++; + } + + $dif = QRinput::estimateBitsModeAn($p) // + 4 + la + + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln + - QRinput::estimateBitsModeAn($q); // - 4 - la + + if($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + + $run = $p; + + if(!self::isalnumat($this->dataStr, $p)) { + $dif = QRinput::estimateBitsModeAn($run) + 4 + $la + + QRinput::estimateBitsMode8(1) // + 4 + l8 + - QRinput::estimateBitsMode8($run + 1); // - 4 - l8 + if($dif > 0) { + return $this->eat8(); + } + } + + $ret = $this->input->append(QR_MODE_AN, $run, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eatKanji() + { + $p = 0; + + while($this->identifyMode($p) == QR_MODE_KANJI) { + $p += 2; + } + + $ret = $this->input->append(QR_MODE_KANJI, $p, str_split($this->dataStr)); + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function eat8() + { + $la = QRspec::lengthIndicator(QR_MODE_AN, $this->input->getVersion()); + $ln = QRspec::lengthIndicator(QR_MODE_NUM, $this->input->getVersion()); + + $p = 1; + $dataStrLen = strlen($this->dataStr); + + while($p < $dataStrLen) { + + $mode = $this->identifyMode($p); + if($mode == QR_MODE_KANJI) { + break; + } + if($mode == QR_MODE_NUM) { + $q = $p; + while(self::isdigitat($this->dataStr, $q)) { + $q++; + } + $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 + + QRinput::estimateBitsModeNum($q - $p) + 4 + $ln + - QRinput::estimateBitsMode8($q); // - 4 - l8 + if($dif < 0) { + break; + } else { + $p = $q; + } + } else if($mode == QR_MODE_AN) { + $q = $p; + while(self::isalnumat($this->dataStr, $q)) { + $q++; + } + $dif = QRinput::estimateBitsMode8($p) // + 4 + l8 + + QRinput::estimateBitsModeAn($q - $p) + 4 + $la + - QRinput::estimateBitsMode8($q); // - 4 - l8 + if($dif < 0) { + break; + } else { + $p = $q; + } + } else { + $p++; + } + } + + $run = $p; + $ret = $this->input->append(QR_MODE_8, $run, str_split($this->dataStr)); + + if($ret < 0) + return -1; + + return $run; + } + + //---------------------------------------------------------------------- + public function splitString() + { + while (strlen($this->dataStr) > 0) + { + if($this->dataStr == '') + return 0; + + $mode = $this->identifyMode(0); + + switch ($mode) { + case QR_MODE_NUM: $length = $this->eatNum(); break; + case QR_MODE_AN: $length = $this->eatAn(); break; + case QR_MODE_KANJI: + if ($hint == QR_MODE_KANJI) + $length = $this->eatKanji(); + else $length = $this->eat8(); + break; + default: $length = $this->eat8(); break; + + } + + if($length == 0) return 0; + if($length < 0) return -1; + + $this->dataStr = substr($this->dataStr, $length); + } + } + + //---------------------------------------------------------------------- + public function toUpper() + { + $stringLen = strlen($this->dataStr); + $p = 0; + + while ($p<$stringLen) { + $mode = self::identifyMode(substr($this->dataStr, $p), $this->modeHint); + if($mode == QR_MODE_KANJI) { + $p += 2; + } else { + if (ord($this->dataStr[$p]) >= ord('a') && ord($this->dataStr[$p]) <= ord('z')) { + $this->dataStr[$p] = chr(ord($this->dataStr[$p]) - 32); + } + $p++; + } + } + + return $this->dataStr; + } + + //---------------------------------------------------------------------- + public static function splitStringToQRinput($string, QRinput $input, $modeHint, $casesensitive = true) + { + if(is_null($string) || $string == '\0' || $string == '') { + throw new Exception('empty string!!!'); + } + + $split = new QRsplit($string, $input, $modeHint); + + if(!$casesensitive) + $split->toUpper(); + + return $split->splitString(); + } + } \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/qrtools.php b/src-backup/includes/phpqrcode/qrtools.php new file mode 100644 index 0000000..3012db4 --- /dev/null +++ b/src-backup/includes/phpqrcode/qrtools.php @@ -0,0 +1,172 @@ + + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + class QRtools { + + //---------------------------------------------------------------------- + public static function binarize($frame) + { + $len = count($frame); + foreach ($frame as &$frameLine) { + + for($i=0; $i<$len; $i++) { + $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0'; + } + } + + return $frame; + } + + //---------------------------------------------------------------------- + public static function tcpdfBarcodeArray($code, $mode = 'QR,L', $tcPdfVersion = '4.5.037') + { + $barcode_array = array(); + + if (!is_array($mode)) + $mode = explode(',', $mode); + + $eccLevel = 'L'; + + if (count($mode) > 1) { + $eccLevel = $mode[1]; + } + + $qrTab = QRcode::text($code, false, $eccLevel); + $size = count($qrTab); + + $barcode_array['num_rows'] = $size; + $barcode_array['num_cols'] = $size; + $barcode_array['bcode'] = array(); + + foreach ($qrTab as $line) { + $arrAdd = array(); + foreach(str_split($line) as $char) + $arrAdd[] = ($char=='1')?1:0; + $barcode_array['bcode'][] = $arrAdd; + } + + return $barcode_array; + } + + //---------------------------------------------------------------------- + public static function clearCache() + { + self::$frames = array(); + } + + //---------------------------------------------------------------------- + public static function buildCache() + { + QRtools::markTime('before_build_cache'); + + $mask = new QRmask(); + for ($a=1; $a <= QRSPEC_VERSION_MAX; $a++) { + $frame = QRspec::newFrame($a); + if (QR_IMAGE) { + $fileName = QR_CACHE_DIR.'frame_'.$a.'.png'; + QRimage::png(self::binarize($frame), $fileName, 1, 0); + } + + $width = count($frame); + $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); + for ($maskNo=0; $maskNo<8; $maskNo++) + $mask->makeMaskNo($maskNo, $width, $frame, $bitMask, true); + } + + QRtools::markTime('after_build_cache'); + } + + //---------------------------------------------------------------------- + public static function log($outfile, $err) + { + if (QR_LOG_DIR !== false) { + if ($err != '') { + if ($outfile !== false) { + file_put_contents(QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); + } else { + file_put_contents(QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); + } + } + } + } + + //---------------------------------------------------------------------- + public static function dumpMask($frame) + { + $width = count($frame); + for($y=0;$y<$width;$y++) { + for($x=0;$x<$width;$x++) { + echo ord($frame[$y][$x]).','; + } + } + } + + //---------------------------------------------------------------------- + public static function markTime($markerId) + { + list($usec, $sec) = explode(" ", microtime()); + $time = ((float)$usec + (float)$sec); + + if (!isset($GLOBALS['qr_time_bench'])) + $GLOBALS['qr_time_bench'] = array(); + + $GLOBALS['qr_time_bench'][$markerId] = $time; + } + + //---------------------------------------------------------------------- + public static function timeBenchmark() + { + self::markTime('finish'); + + $lastTime = 0; + $startTime = 0; + $p = 0; + + echo ' + + '; + + foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) { + if ($p > 0) { + echo ''; + } else { + $startTime = $thisTime; + } + + $p++; + $lastTime = $thisTime; + } + + echo ' + + +
BENCHMARK
till '.$markerId.': '.number_format($thisTime-$lastTime, 6).'s
TOTAL: '.number_format($lastTime-$startTime, 6).'s
'; + } + + } + + //########################################################################## + + QRtools::markTime('start'); + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/tools/merge.bat b/src-backup/includes/phpqrcode/tools/merge.bat new file mode 100755 index 0000000..b60a485 --- /dev/null +++ b/src-backup/includes/phpqrcode/tools/merge.bat @@ -0,0 +1,2 @@ +php ./merge.php +pause \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/tools/merge.php b/src-backup/includes/phpqrcode/tools/merge.php new file mode 100644 index 0000000..19d338b --- /dev/null +++ b/src-backup/includes/phpqrcode/tools/merge.php @@ -0,0 +1,70 @@ + + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + $QR_BASEDIR = dirname(__FILE__).DIRECTORY_SEPARATOR.'..'.DIRECTORY_SEPARATOR; + $QR_TOOLSDIR = dirname(__FILE__).DIRECTORY_SEPARATOR; + + $outputFile = $QR_BASEDIR.'phpqrcode.php'; + + // Required libs + + $fileList = array( + $QR_BASEDIR.'qrconst.php', + $QR_TOOLSDIR.'merged_config.php', + $QR_BASEDIR.'qrtools.php', + $QR_BASEDIR.'qrspec.php', + $QR_BASEDIR.'qrimage.php', + $QR_BASEDIR.'qrinput.php', + $QR_BASEDIR.'qrbitstream.php', + $QR_BASEDIR.'qrsplit.php', + $QR_BASEDIR.'qrrscode.php', + $QR_BASEDIR.'qrmask.php', + $QR_BASEDIR.'qrencode.php' + ); + + $headerFile = $QR_TOOLSDIR.'merged_header.php'; + $versionFile = $QR_BASEDIR.'VERSION'; + + $outputCode = ''; + + foreach($fileList as $fileName) { + $outputCode .= "\n\n".'//---- '.basename($fileName).' -----------------------------'."\n\n"; + $anotherCode = file_get_contents($fileName); + $anotherCode = preg_replace ('/^<\?php/', '', $anotherCode); + $anotherCode = preg_replace ('/\?>\*$/', '', $anotherCode); + $outputCode .= "\n\n".$anotherCode."\n\n"; + } + + $versionDataEx = explode("\n", file_get_contents($versionFile)); + + $outputContents = file_get_contents($headerFile); + $outputContents .= "\n\n/*\n * Version: ".trim($versionDataEx[0])."\n * Build: ".trim($versionDataEx[1])."\n */\n\n"; + $outputContents .= $outputCode; + + file_put_contents($outputFile, $outputContents); + + \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/tools/merge.sh b/src-backup/includes/phpqrcode/tools/merge.sh new file mode 100644 index 0000000..e4c2fbc --- /dev/null +++ b/src-backup/includes/phpqrcode/tools/merge.sh @@ -0,0 +1,2 @@ +#!/bin/sh +php ./merge.php \ No newline at end of file diff --git a/src-backup/includes/phpqrcode/tools/merged_config.php b/src-backup/includes/phpqrcode/tools/merged_config.php new file mode 100644 index 0000000..55ddb45 --- /dev/null +++ b/src-backup/includes/phpqrcode/tools/merged_config.php @@ -0,0 +1,17 @@ + + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA + */ + + \ No newline at end of file diff --git a/src-backup/index.php b/src-backup/index.php new file mode 100644 index 0000000..05777e7 --- /dev/null +++ b/src-backup/index.php @@ -0,0 +1,690 @@ + 0) { + $row = mysqli_fetch_assoc($result); + return number_format($row['total']); + } + return $default; + } catch (Exception $e) { + return $default; + } +} + +// Get statistics +$active_students = getDatabaseStats("SELECT COUNT(*) as total FROM students WHERE status = 1", '0'); +$course_count = getDatabaseStats("SELECT COUNT(DISTINCT id) as total FROM courses WHERE status = 1", '12'); +$today_checkins = getDatabaseStats("SELECT COUNT(*) as total FROM attendance WHERE DATE(created_at) = CURDATE()", '0'); +?> + + + + + + + Attendance Management System - Aldersgate College + + + + + + + + + + + + + + + +
+
+
+
+

Attendance Management System

+

+ A modern, efficient, and contactless attendance system using QR code technology. + Perfect for Aldersgate College's digital transformation needs. +

+ +
+
+
+ Aldersgate College Logo +
+
+
+
+
+ + +
+
+
+
+
+
+
Active Students
+
+
+
+
+
+
Courses
+
+
+
+
+
+
Today's Check-ins
+
+
+
+
+
99.9%
+
Accuracy Rate
+
+
+
+
+
+ + +
+
+

Key Features

+
+
+
+
+ +
+

QR Code Attendance

+

+ Quick and contactless attendance marking with unique student QR codes. +

+
+
+
+
+
+ +
+

Real-time Analytics

+

+ Comprehensive dashboards and detailed attendance reports. +

+
+
+
+
+
+ +
+

Student Management

+

+ Manage profiles, courses, and departments with bulk import. +

+
+
+
+
+
+ +
+

Activity Scheduling

+

+ Schedule classes, seminars, and events with specific time slots. +

+
+
+
+
+
+ +
+

Smart Notifications

+

+ Automated alerts for attendance, events, and announcements. +

+
+
+
+
+
+ +
+

Secure & Reliable

+

+ Role-based access control with enterprise-grade security. +

+
+
+
+
+
+ + +
+
+
+
+ +

Aldersgate College

+

+ Solano, Nueva Vizcaya
+ Excellence in Education Since 1947 +

+
+
+

About This System

+

+ Developed specifically for Aldersgate College, this system modernizes and + streamlines attendance tracking across all departments and courses with + cutting-edge QR code technology. +

+
+
+
+ +
+
Contactless Operation
+ No physical contact required +
+
+
+
+
+ +
+
Real-time Tracking
+ Live attendance monitoring +
+
+
+
+
+ +
+
Easy Integration
+ Works with existing systems +
+
+
+
+
+ +
+
Mobile Ready
+ Accessible on all devices +
+
+
+
+ +
+
+
+
+ + +
+
+
+
+
Attendance Management System
+

+ A comprehensive solution for modernizing attendance tracking + at Aldersgate College with QR code technology. +

+
+ + +
+
+
+
Quick Links
+ +
+
+
Contact Info
+ +
+
+ +
+
+ + + + + + + \ No newline at end of file diff --git a/src-backup/qr/cleanup_qrcodes.php b/src-backup/qr/cleanup_qrcodes.php new file mode 100644 index 0000000..9dcc3d3 --- /dev/null +++ b/src-backup/qr/cleanup_qrcodes.php @@ -0,0 +1,18 @@ += 3600) { + @unlink($file); + } + } + } +} +?> \ No newline at end of file diff --git a/src-backup/qr/generate.php b/src-backup/qr/generate.php new file mode 100644 index 0000000..bd7f3d2 --- /dev/null +++ b/src-backup/qr/generate.php @@ -0,0 +1,593 @@ +Error: Student ID required.
'); +} + +$student_id = intval($_GET['id']); + +// Get student data +$sql = "SELECT s.*, c.code as course_code, c.name as course_name, + d.name as department_name, sc.name as school_name + FROM students s + LEFT JOIN courses c ON s.course_id = c.id + LEFT JOIN departments d ON s.department_id = d.id + LEFT JOIN schools sc ON s.school_id = sc.id + WHERE s.id = ?"; + +$stmt = mysqli_prepare($conn, $sql); +mysqli_stmt_bind_param($stmt, 'i', $student_id); +mysqli_stmt_execute($stmt); +$result = mysqli_stmt_get_result($stmt); + +if (!$result || mysqli_num_rows($result) == 0) { + die('
Error: Student not found.
'); +} + +$student = mysqli_fetch_assoc($result); +mysqli_stmt_close($stmt); + +// Check if download or print is requested +$download = isset($_GET['download']) && $_GET['download'] == '1'; +$print = isset($_GET['print']) && $_GET['print'] == '1'; +$auto_print = isset($_GET['autoPrint']) && $_GET['autoPrint'] == '1'; + +// QR code content +$qr_data = [ + 'ID' => $student['student_id'], + 'Name' => $student['full_name'], + 'Course' => $student['course_code'], + 'Dept' => $student['department_name'], + 'Year' => 'Year ' . $student['year_level'], + 'Code' => $student['qr_code'] +]; + +$qr_text = ""; +foreach ($qr_data as $key => $value) { + $qr_text .= "$key: $value\n"; +} + +// Create temp directory +$temp_dir = '../temp_qrcodes/'; +if (!file_exists($temp_dir)) { + mkdir($temp_dir, 0777, true); +} + +// Generate QR code +$filename = 'qr_' . $student['student_id'] . '_' . time() . '.png'; +$filepath = $temp_dir . $filename; +$qr_size = isset($_GET['size']) ? intval($_GET['size']) : 250; + +// Generate QR code from Google Charts +$encoded_text = urlencode(trim($qr_text)); +$qr_url = "https://chart.googleapis.com/chart?chs={$qr_size}x{$qr_size}&cht=qr&chl={$encoded_text}&choe=UTF-8"; +$image_data = @file_get_contents($qr_url); + +if ($image_data === false) { + // Fallback + $qr_url = "https://api.qrserver.com/v1/create-qr-code/?size={$qr_size}x{$qr_size}&data=" . urlencode($qr_text); + $image_data = @file_get_contents($qr_url); +} + +if ($image_data !== false) { + file_put_contents($filepath, $image_data); +} + +// If download requested +if ($download) { + if (file_exists($filepath)) { + header('Content-Type: application/octet-stream'); + header('Content-Disposition: attachment; filename="QR_' . $student['student_id'] . '.png"'); + header('Content-Length: ' . filesize($filepath)); + readfile($filepath); + cleanupOldQRCodes($temp_dir); + exit(); + } +} + +// If print requested +if ($print || $auto_print) { + ?> + + + + QR - <?php echo $student['full_name']; ?> + + + + +
+
+

+

+
+ + QR Code + +
+
+
+ +
+

+

Year |

+
+
+ + + + + + + + + + QR - <?php echo htmlspecialchars($student['full_name']); ?> + + + + + +
+
+

Student QR Code

+
+ +
+ +
+ + QR Code + +
+ + QR code generation failed +
+
+
+
+ + +
+ +
+ +
+ + + +
+
+ + +
+
+ + Photo + +
+ +
+ + +
+
+
+
+
+ +
+
+
Course
+
+
+ +
+
Department
+
+
+ +
+
Year
+
Year
+
+ +
+
School
+
+
+ +
+
Email
+
+ +
+
+ +
+
Contact
+
+ +
+
+ +
+
Status
+
+ + + Active + + + + Inactive + + +
+
+ +
+
Generated
+
+
+
+ +
+ + Last updated: +
+
+
+ +
+ + + + + + Quick Print + + + + Direct Download + + + +
+
+ + + + + + + += 3600)) { + @unlink($file); + } + } + } +} + +// Run cleanup +cleanupOldQRCodes($temp_dir); +?> \ No newline at end of file diff --git a/src-backup/qr/print.php b/src-backup/qr/print.php new file mode 100644 index 0000000..ff110e1 --- /dev/null +++ b/src-backup/qr/print.php @@ -0,0 +1,194 @@ + + + + + + + Print QR Code - <?php echo $student['full_name']; ?> + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src-backup/qr/simple_cleanup.php b/src-backup/qr/simple_cleanup.php new file mode 100644 index 0000000..097a830 --- /dev/null +++ b/src-backup/qr/simple_cleanup.php @@ -0,0 +1,22 @@ + 3600) { + if (unlink($file)) { + $deleted++; + } + } + } + + echo "Deleted $deleted old QR code files."; +} else { + echo "QR directory not found."; +} +?> \ No newline at end of file diff --git a/src-backup/qr/test_gd.php b/src-backup/qr/test_gd.php new file mode 100644 index 0000000..d2b25e4 --- /dev/null +++ b/src-backup/qr/test_gd.php @@ -0,0 +1,3 @@ + \ No newline at end of file diff --git a/src-backup/reports/print_report.php b/src-backup/reports/print_report.php new file mode 100644 index 0000000..6942289 --- /dev/null +++ b/src-backup/reports/print_report.php @@ -0,0 +1,356 @@ +AddPage(); + // $pdf->writeHTML($html); + // $pdf->Output(); + exit(); +} +?> + + + + + + + Student Report + + + +
+ + + + +
+
Student Report
+
Generated on
+
+ + +
+
+
Total Students:
+
Page: 1 of 1
+
+
+
+ Filters Applied: + +
+
Generated By:
+
+
+ + + + + + + + + + + + + + + + + + + + 0, 2 => 0, 3 => 0, 4 => 0]; + + foreach ($students as $student): + if ($student['status'] == 1) $active_count++; + else $inactive_count++; + + $year_counts[$student['year_level']]++; + ?> + + + + + + + + + + + + + + +
#Student IDFull NameGenderYear LevelCourseEmailContactStatusDate Registered
Year + + Active + + Inactive + +
+ + +
+

Summary

+
+
+ Total Students: +
+
+ Active: +
+
+ Inactive: +
+ $count): ?> +
+ Year : +
+ +
+
+ +
+

No students found matching the selected criteria

+

Try adjusting your filters.

+
+ + + + +
+ + + + \ No newline at end of file diff --git a/src-backup/reports/students_report.php b/src-backup/reports/students_report.php new file mode 100644 index 0000000..886306e --- /dev/null +++ b/src-backup/reports/students_report.php @@ -0,0 +1,375 @@ += '" . escape($conn, $date_from) . "'"; + } + + if (!empty($date_to)) { + $sql .= " AND DATE(s.created_at) <= '" . escape($conn, $date_to) . "'"; + } + + $sql .= " ORDER BY s.created_at DESC"; + + $result = query($conn, $sql); + $students = []; + while ($row = mysqli_fetch_assoc($result)) { + $students[] = $row; + } + + // Generate PDF + if ($report_type === 'pdf') { + require_once '../vendor/autoload.php'; // If using TCPDF or Dompdf + + // For now, we'll create a simple HTML report that can be printed + // In production, you'd use a PDF library like TCPDF or Dompdf + $_SESSION['report_data'] = [ + 'students' => $students, + 'filters' => [ + 'status' => $status_filter, + 'year_level' => $year_level_filter, + 'course' => $course_filter, + 'date_from' => $date_from, + 'date_to' => $date_to + ] + ]; + + header('Location: print_report.php?type=pdf'); + exit(); + } + // Generate Excel + elseif ($report_type === 'excel') { + require_once '../includes/PHPExcel.php'; // Or use PhpSpreadsheet + + // Create Excel file + $filename = "students_report_" . date('Y-m-d_H-i-s') . ".xlsx"; + header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); + header('Content-Disposition: attachment; filename="' . $filename . '"'); + + // For now, create CSV as fallback + outputCSV($students); + exit(); + } + // Print view + elseif ($report_type === 'print') { + $_SESSION['report_data'] = [ + 'students' => $students, + 'filters' => [ + 'status' => $status_filter, + 'year_level' => $year_level_filter, + 'course' => $course_filter, + 'date_from' => $date_from, + 'date_to' => $date_to + ] + ]; + + header('Location: print_report.php'); + exit(); + } +} + +// Get courses for filter dropdown +$courses = []; +$result = query($conn, "SELECT id, code, name FROM courses WHERE status = 1 ORDER BY code"); +while ($row = mysqli_fetch_assoc($result)) { + $courses[] = $row; +} + +// Get departments +$departments = []; +$result = query($conn, "SELECT id, code, name FROM departments WHERE status = 1 ORDER BY code"); +while ($row = mysqli_fetch_assoc($result)) { + $departments[] = $row; +} + +function outputCSV($data) { + $output = fopen('php://output', 'w'); + + // Header row + fputcsv($output, [ + 'Student ID', 'Full Name', 'Gender', 'Year Level', 'Course', + 'Department', 'Email', 'Contact Number', 'Status', 'Date Created' + ]); + + // Data rows + foreach ($data as $student) { + fputcsv($output, [ + $student['student_id'], + $student['full_name'], + $student['gender'], + 'Year ' . $student['year_level'], + $student['course_code'] . ' - ' . $student['course_name'], + $student['department_name'], + $student['email'], + $student['contact_number'], + $student['status'] == 1 ? 'Active' : 'Inactive', + date('Y-m-d', strtotime($student['created_at'])) + ]); + } + + fclose($output); +} + +include '../includes/header.php'; +?> + + +
+
+

Student Reports

+

Generate and export student reports in various formats.

+
+
+ + Back to Students + +
+
+ + + +
+ + +
+ + + +
+
+
+ Report Filters +
+
+
+
+
+
+ + +
+ +
+ + +
+ +
+ + +
+ +
+ + +
+ +
+ + +
+ +
+ + +
+ +
+
+ + +
+
+
+
+
+
+ + +
+
+
+
+ +
Quick Print
+

Generate a printable student list

+
+ + + +
+
+
+
+ +
+
+
+ +
Export Excel
+

Download as Excel spreadsheet

+
+ + + +
+
+
+
+ +
+
+
+ +
PDF Report
+

Generate detailed PDF report

+
+ + + +
+
+
+
+
+ + +$(document).ready(function() { + // Set today as default date for "Date To" + const today = new Date().toISOString().split("T")[0]; + $("input[name=\'date_to\']").val(today); + + // Set 30 days ago as default for "Date From" + const thirtyDaysAgo = new Date(); + thirtyDaysAgo.setDate(thirtyDaysAgo.getDate() - 30); + $("input[name=\'date_from\']").val(thirtyDaysAgo.toISOString().split("T")[0]); + + // Form validation + $("form").submit(function() { + const dateFrom = $("input[name=\'date_from\']").val(); + const dateTo = $("input[name=\'date_to\']").val(); + + if (dateFrom && dateTo && new Date(dateFrom) > new Date(dateTo)) { + showNotification("Date From cannot be after Date To", "danger"); + return false; + } + + showLoader("Generating report..."); + return true; + }); +}); + +// Quick export functions +function exportActiveStudents() { + showConfirm("Export all active students to Excel?", function(confirmed) { + if (confirmed) { + const form = document.createElement("form"); + form.method = "POST"; + form.action = ""; + + const typeInput = document.createElement("input"); + typeInput.type = "hidden"; + typeInput.name = "report_type"; + typeInput.value = "excel"; + form.appendChild(typeInput); + + const statusInput = document.createElement("input"); + statusInput.type = "hidden"; + statusInput.name = "status_filter"; + statusInput.value = "1"; + form.appendChild(statusInput); + + document.body.appendChild(form); + form.submit(); + } + }); +} + +function printStudentCards() { + showConfirm("Generate printable student ID cards?", function(confirmed) { + if (confirmed) { + window.open("student_cards.php", "_blank"); + } + }); +} + +'; + +include '../includes/footer.php'; +?> \ No newline at end of file diff --git a/src-backup/save_draft.php b/src-backup/save_draft.php new file mode 100644 index 0000000..a08eeff --- /dev/null +++ b/src-backup/save_draft.php @@ -0,0 +1,18 @@ + true, + 'message' => 'Draft saved successfully', + 'timestamp' => date('h:i:s A') + ]); +} +?> \ No newline at end of file diff --git a/src-backup/setup.php b/src-backup/setup.php new file mode 100644 index 0000000..98aefb7 --- /dev/null +++ b/src-backup/setup.php @@ -0,0 +1,258 @@ + + + + + + Attendance System Setup Check + + + + +
+

🏫 QR Attendance System Setup

+
+ Checking system requirements... +
"; + +echo "

📋 System Requirements Check

"; +echo "
"; + +// 1. Check PHP version +if (version_compare(PHP_VERSION, '7.4.0') >= 0) { + echo "
✓ PHP 7.4+ is installed (Current: " . PHP_VERSION . ")
"; +} else { + echo "
✗ PHP 7.4+ is required (Current: " . PHP_VERSION . ")
"; +} + +// 2. Check MySQLi extension +if (extension_loaded('mysqli')) { + echo "
✓ MySQLi extension is enabled
"; +} else { + echo "
✗ MySQLi extension is required
"; +} + +// 3. Check session support +if (function_exists('session_start')) { + echo "
✓ Session support is enabled
"; +} else { + echo "
✗ Session support is required
"; +} + +echo "
"; + +echo "

🗄️ Database Connection Check

"; +echo "
"; + +// Database connection test +$host = 'localhost'; +$user = 'root'; +$pass = ''; +$dbname = 'attendance_system'; + +$conn = @mysqli_connect($host, $user, $pass); +if ($conn) { + echo "
✓ Connected to MySQL server
"; + + // Check if database exists + $db_selected = @mysqli_select_db($conn, $dbname); + if ($db_selected) { + echo "
✓ Database '$dbname' exists
"; + + // Check required tables + $required_tables = [ + 'users' => 'Users table', + 'students' => 'Students table', + 'activities' => 'Activities table', + 'attendance' => 'Attendance table', + 'courses' => 'Courses table', + 'departments' => 'Departments table', + 'genders' => 'Genders table', + 'schools' => 'Schools table' + ]; + + foreach ($required_tables as $table => $description) { + $result = @mysqli_query($conn, "SHOW TABLES LIKE '$table'"); + if ($result && mysqli_num_rows($result) > 0) { + echo "
✓ $description exists
"; + } else { + echo "
✗ $description is missing
"; + } + } + + // Check if there are users in the database + $result = @mysqli_query($conn, "SELECT COUNT(*) as count FROM users"); + if ($result) { + $row = mysqli_fetch_assoc($result); + if ($row['count'] > 0) { + echo "
✓ Users found in database
"; + + // Show sample users + $result = @mysqli_query($conn, "SELECT username, role, full_name FROM users LIMIT 3"); + if ($result && mysqli_num_rows($result) > 0) { + echo "
Sample users:
"; + while ($user = mysqli_fetch_assoc($result)) { + echo "• {$user['username']} ({$user['role']}) - {$user['full_name']}
"; + } + echo "
"; + } + } else { + echo "
⚠ No users found in database
"; + } + } + + } else { + echo "
✗ Database '$dbname' does not exist
"; + echo "
"; + echo "Please import the SQL file first:
"; + echo "mysql -u root -p attendance_system < attendance_system.sql"; + echo "
"; + } + + mysqli_close($conn); +} else { + echo "
✗ Cannot connect to MySQL server
"; + echo "
"; + echo "MySQL Error: " . mysqli_connect_error() . "
"; + echo "Please check your database credentials in includes/config.php"; + echo "
"; +} + +echo "
"; + +echo "

📁 Directory Structure Check

"; +echo "
"; + +// Check directory structure +$required_dirs = [ + 'includes' => 'Configuration files', + 'assets/css' => 'CSS stylesheets', + 'assets/js' => 'JavaScript files', + 'admin' => 'Admin pages', + 'teacher' => 'Teacher pages', + 'student' => 'Student pages', + 'auth' => 'Authentication pages', + 'api' => 'API endpoints', + 'qr/generated' => 'QR code storage' +]; + +foreach ($required_dirs as $dir => $description) { + if (is_dir($dir)) { + echo "
✓ Directory '$dir' exists
"; + + // Check if directory is writable (for qr/generated) + if (in_array($dir, ['qr/generated'])) { + if (is_writable($dir)) { + echo "
✓ Directory '$dir' is writable
"; + } else { + echo "
⚠ Directory '$dir' is not writable
"; + } + } + } else { + echo "
✗ Directory '$dir' is missing
"; + } +} + +echo "
"; + +echo "

📄 Required Files Check

"; +echo "
"; + +// Check required files +$required_files = [ + 'includes/config.php' => 'Configuration file', + 'auth/login.php' => 'Login page', + 'admin/dashboard.php' => 'Admin dashboard', + 'admin/attendance.php' => 'QR scanner page', + 'api/scan_qr.php' => 'QR scanning API', + 'index.php' => 'Main entry point' +]; + +foreach ($required_files as $file => $description) { + if (file_exists($file)) { + $size = filesize($file); + echo "
✓ $description exists (" . round($size/1024, 2) . " KB)
"; + } else { + echo "
✗ $description is missing
"; + } +} + +echo "
"; + +echo "

🚀 Quick Actions

"; +echo "
"; +echo ""; + +echo ""; + +echo ""; +echo "
"; + +echo "
"; +echo "
Setup Instructions:
"; +echo "
    "; +echo "
  1. Import the SQL file to your database
  2. "; +echo "
  3. Update database credentials in includes/config.php
  4. "; +echo "
  5. Make sure qr/generated/ directory is writable
  6. "; +echo "
  7. Access the system via: http://localhost/attendance_system/
  8. "; +echo "
  9. Login with default credentials: johnlloyd12 / password
  10. "; +echo "
"; +echo "
"; + +echo "
"; +echo "
Security Notes:
"; +echo "
    "; +echo "
  • Change default passwords after first login
  • "; +echo "
  • Disable error display in production (set display_errors = Off in php.ini)
  • "; +echo "
  • Use HTTPS in production environment
  • "; +echo "
  • Regularly backup your database
  • "; +echo "
"; +echo "
"; + +echo "
"; +echo "QR Attendance System v1.0 | " . date('Y-m-d H:i:s') . ""; +echo "
"; + +echo "
+ + +"; +?> \ No newline at end of file diff --git a/src-backup/temp_qrcodes/qr_016-0128_1766215818.png b/src-backup/temp_qrcodes/qr_016-0128_1766215818.png new file mode 100644 index 0000000..9a3ab76 Binary files /dev/null and b/src-backup/temp_qrcodes/qr_016-0128_1766215818.png differ diff --git a/src-backup/test_connection.php b/src-backup/test_connection.php new file mode 100644 index 0000000..937196d --- /dev/null +++ b/src-backup/test_connection.php @@ -0,0 +1,55 @@ +"; +echo "Current directory: " . __DIR__ . "

"; + +// Test direct connection +try { + $pdo_test = new PDO( + "mysql:host=localhost;dbname=attendance_system;charset=utf8mb4", + "root", + "", + [ + PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, + PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC + ] + ); + + echo "✅ Direct database connection successful!
"; + + // Test query + $stmt = $pdo_test->query("SELECT COUNT(*) as count FROM users"); + $result = $stmt->fetch(); + echo "✅ Database query successful!
"; + echo "Total users: " . $result['count'] . "
"; + +} catch (PDOException $e) { + echo "❌ Database connection failed: " . $e->getMessage() . "
"; +} + +echo "
Now testing includes/database.php...
"; + +$path = __DIR__ . '/includes/database.php'; +echo "Looking for file at: " . $path . "
"; + +if (file_exists($path)) { + echo "✅ File exists!
"; + + // Include the file + require_once $path; + + if (isset($pdo)) { + echo "✅ \$pdo variable is set!
"; + + try { + $stmt = $pdo->query("SELECT 1"); + echo "✅ Database query through includes/database.php works!
"; + } catch (Exception $e) { + echo "❌ Query failed: " . $e->getMessage() . "
"; + } + } else { + echo "❌ \$pdo variable is NOT set!
"; + } +} else { + echo "❌ File does NOT exist!
"; +} +?> \ No newline at end of file diff --git a/src-backup/test_db.php b/src-backup/test_db.php new file mode 100644 index 0000000..6b1a837 --- /dev/null +++ b/src-backup/test_db.php @@ -0,0 +1,13 @@ +"; + +try { + // Test query + $stmt = $pdo->query("SELECT COUNT(*) as count FROM users"); + $result = $stmt->fetch(); + echo "Total users in database: " . $result['count']; +} catch (Exception $e) { + echo "Error: " . $e->getMessage(); +} +?> \ No newline at end of file diff --git a/src.zip b/src.zip new file mode 100644 index 0000000..3d62867 Binary files /dev/null and b/src.zip differ diff --git a/src/admin/activities.php b/src/admin/activities.php new file mode 100644 index 0000000..49f8505 --- /dev/null +++ b/src/admin/activities.php @@ -0,0 +1,293 @@ +query('SELECT id, name FROM courses WHERE status = 1 ORDER BY name')->fetchAll(); +$departments = $pdo->query('SELECT id, name FROM departments WHERE status = 1 ORDER BY name')->fetchAll(); + +if (is_post()) { + if (!validate_csrf_token($_POST['csrf_token'] ?? null)) { + $errors[] = 'Invalid session token.'; + } else { + $action = $_POST['action'] ?? 'create'; + + if ($action === 'delete') { + $id = (int) ($_POST['id'] ?? 0); + $pdo->prepare('DELETE FROM activities WHERE id = :id')->execute(['id' => $id]); + add_flash('success', 'Activity removed.'); + redirect('admin/activities.php'); + } + + $payload = [ + 'name' => trim($_POST['name'] ?? ''), + 'date' => $_POST['date'] ?? null, + 'time_in' => $_POST['time_in'] ?? null, + 'time_out' => $_POST['time_out'] ?? null, + 'location' => trim($_POST['location'] ?? ''), + 'required_students' => $_POST['required_students'] ?? 'all', + 'course_id' => $_POST['required_students'] === 'specific_course' ? (int) ($_POST['course_id'] ?? 0) : null, + 'department_id' => $_POST['required_students'] === 'specific_department' ? (int) ($_POST['department_id'] ?? 0) : null, + 'description' => trim($_POST['description'] ?? ''), + 'status' => (int) ($_POST['status'] ?? 1), + 'created_by' => current_user()['id'], + ]; + + if ($payload['name'] === '' || !$payload['date']) { + $errors[] = 'Activity name and date are required.'; + } + + if (!$errors) { + if ($action === 'update') { + $updatePayload = $payload; + $updatePayload['id'] = (int) ($_POST['id'] ?? 0); + unset($updatePayload['created_by']); + $stmt = $pdo->prepare( + 'UPDATE activities SET name = :name, date = :date, time_in = :time_in, time_out = :time_out, + location = :location, required_students = :required_students, course_id = :course_id, + department_id = :department_id, description = :description, status = :status + WHERE id = :id' + ); + $stmt->execute($updatePayload); + add_flash('success', 'Activity updated.'); + } else { + $stmt = $pdo->prepare( + 'INSERT INTO activities (name, date, time_in, time_out, location, required_students, + course_id, department_id, description, status, created_by) + VALUES (:name, :date, :time_in, :time_out, :location, :required_students, + :course_id, :department_id, :description, :status, :created_by)' + ); + $stmt->execute($payload); + add_flash('success', 'Activity scheduled.'); + } + + redirect('admin/activities.php'); + } + } +} + +$activities = $pdo->query( + 'SELECT a.*, c.name AS course_name, d.name AS department_name, u.full_name AS creator + FROM activities a + LEFT JOIN courses c ON a.course_id = c.id + LEFT JOIN departments d ON a.department_id = d.id + LEFT JOIN users u ON a.created_by = u.id + ORDER BY a.date DESC, a.time_in DESC' +)->fetchAll(); + +render_header('Activities', ['active' => 'activities']); +?> +
+
+
+
Activities
+ scheduled +
+
+ + + + +
+
+
+ +

No activities scheduled.

+ +
+ + + + + + + + + + + + + + (int) $activity['id'], + 'name' => $activity['name'], + 'date' => $activity['date'], + 'time_in' => $activity['time_in'], + 'time_out' => $activity['time_out'], + 'location' => $activity['location'], + 'required_students' => $activity['required_students'], + 'course_id' => $activity['course_id'], + 'department_id' => $activity['department_id'], + 'description' => $activity['description'], + 'status' => (int) $activity['status'], + ]); + $timeIn = $activity['time_in'] !== null ? substr($activity['time_in'], 0, 5) : '—'; + $timeOut = $activity['time_out'] !== null ? substr($activity['time_out'], 0, 5) : '—'; + ?> + + + + + + + + + + +
NameDateAudienceLocationStatusActions
+
+ Created by +
+
+ +
+ $activity['course_name'] ?? 'Course', + 'specific_department' => $activity['department_name'] ?? 'Department', + default => 'All Students', + }; + ?> + + + + + + + + +
+
+ +
+
+ + + + + + +query( + 'SELECT id, name, date, time_in, time_out + FROM activities + WHERE status = 1 AND date >= CURDATE() - INTERVAL 1 DAY + ORDER BY date DESC, time_in DESC' +)->fetchAll(); +$hasActivities = !empty($activities); + +$todayAttendance = $pdo->query( + 'SELECT att.*, s.full_name, s.student_id, act.name AS activity_name + FROM attendance att + INNER JOIN students s ON att.student_id = s.id + INNER JOIN activities act ON att.activity_id = act.id + WHERE DATE(att.time_in) = CURDATE() + ORDER BY att.time_in DESC' +)->fetchAll(); + +render_header('Scan Center', ['active' => 'attendance']); +?> +
+
+
+

Admin Scan Center

+

Only signed-in administrators can scan QR codes. Use the camera or type the token below.

+ +
+ No active activities available. Create one first to start scanning. +
+ +
+
+ + +
+
+ + required> +
+
+ + +
+
+ + +
+

+ The scanner auto-selects the best camera mode and falls back to a built-in detector if needed. +

+
+
+

+
+
Camera idle
+
+
+
+
+
+
+
+
Today’s Attendance
+ captured +
+
+
+ +

No scans recorded today.

+ +
+ + + + + + + + + + + + + + + + + + + + + +
StudentActivityTime InTime OutStatus
+
+ +
+ + + +
+
+ +
+
+
+
+ [ + 'https://unpkg.com/html5-qrcode@2.3.10/html5-qrcode.min.js', + ], +]); diff --git a/src/admin/courses.php b/src/admin/courses.php new file mode 100644 index 0000000..c0911a0 --- /dev/null +++ b/src/admin/courses.php @@ -0,0 +1,223 @@ +query('SELECT id, name FROM departments WHERE status = 1 ORDER BY name')->fetchAll(); + +if (is_post()) { + if (!validate_csrf_token($_POST['csrf_token'] ?? null)) { + $errors[] = 'Invalid session token.'; + } else { + $action = $_POST['action'] ?? 'create'; + + if ($action === 'delete') { + $id = (int) ($_POST['id'] ?? 0); + $pdo->prepare('DELETE FROM courses WHERE id = :id')->execute(['id' => $id]); + add_flash('success', 'Course removed.'); + redirect('admin/courses.php'); + } + + $payload = [ + 'code' => strtoupper(trim($_POST['code'] ?? '')), + 'name' => trim($_POST['name'] ?? ''), + 'department_id' => (int) ($_POST['department_id'] ?? 0), + 'description' => trim($_POST['description'] ?? ''), + 'status' => (int) ($_POST['status'] ?? 1), + ]; + + if ($payload['code'] === '' || $payload['name'] === '') { + $errors[] = 'Course code and name are required.'; + } + + if (!$errors) { + if ($action === 'update') { + $payload['id'] = (int) ($_POST['id'] ?? 0); + $stmt = $pdo->prepare( + 'UPDATE courses SET code = :code, name = :name, department_id = :department_id, + description = :description, status = :status WHERE id = :id' + ); + $stmt->execute($payload); + add_flash('success', 'Course updated.'); + } else { + $stmt = $pdo->prepare( + 'INSERT INTO courses (code, name, department_id, description, status) + VALUES (:code, :name, :department_id, :description, :status)' + ); + $stmt->execute($payload); + add_flash('success', 'Course added.'); + } + + redirect('admin/courses.php'); + } + } +} + +$courses = $pdo->query( + 'SELECT c.*, d.name AS department_name + FROM courses c + LEFT JOIN departments d ON c.department_id = d.id + ORDER BY c.name ASC' +)->fetchAll(); + +render_header('Courses', ['active' => 'courses']); +?> +
+
+
+
Courses
+ total +
+
+ + + + +
+
+
+ +

No courses yet.

+ +
+ + + + + + + + + + + + + (int) $course['id'], + 'code' => $course['code'], + 'name' => $course['name'], + 'department_id' => (int) ($course['department_id'] ?? 0), + 'description' => $course['description'], + 'status' => (int) $course['status'], + ]); + ?> + + + + + + + + + +
CodeNameDepartmentStatusActions
+ + + + + + +
+
+ +
+
+ + + + + + + (int) $pdo->query('SELECT COUNT(*) FROM students')->fetchColumn(), + 'activities' => (int) $pdo->query('SELECT COUNT(*) FROM activities WHERE status = 1')->fetchColumn(), + 'attendance_today' => (int) $pdo->query('SELECT COUNT(*) FROM attendance WHERE DATE(time_in) = CURDATE()')->fetchColumn(), + 'users' => (int) $pdo->query('SELECT COUNT(*) FROM users WHERE status = 1')->fetchColumn(), +]; + +$upcomingActivities = $pdo->query( + 'SELECT a.*, d.name AS department_name, c.name AS course_name + FROM activities a + LEFT JOIN departments d ON a.department_id = d.id + LEFT JOIN courses c ON a.course_id = c.id + WHERE a.date >= CURDATE() + ORDER BY a.date ASC, a.time_in ASC + LIMIT 5' +)->fetchAll(); + +$recentAttendance = $pdo->query( + 'SELECT att.*, s.full_name, act.name AS activity_name + FROM attendance att + INNER JOIN students s ON att.student_id = s.id + INNER JOIN activities act ON att.activity_id = act.id + ORDER BY att.updated_at DESC + LIMIT 10' +)->fetchAll(); + +render_header('Dashboard', ['active' => 'dashboard']); +?> +
+
+
+
Registered Students
+

+
+
+
+
+
Active Activities
+

+
+
+
+
+
Attendance (Today)
+

+
+
+
+
+
Active Users
+

+
+
+
+ +
+
+
+
+
+
Upcoming Activities
+ Manage +
+
+
+ +

No scheduled activities yet.

+ +
+ +
+
+
+
+
+ • + + — + +
+ + + + + +
+ + + +
+
+ +
+ +
+
+
+ +
+
+
+
Latest Attendance Logs
+
+
+ +

No attendance captured yet.

+ +
+ + + + + + + + + + + + + + + + + + + +
StudentActivityStatusRecorded
+ + + +
+
+ +
+
+
+
+query('SELECT id, name FROM schools WHERE status = 1 ORDER BY name')->fetchAll(); + +if (is_post()) { + if (!validate_csrf_token($_POST['csrf_token'] ?? null)) { + $errors[] = 'Invalid session token.'; + } else { + $action = $_POST['action'] ?? 'create'; + + if ($action === 'delete') { + $id = (int) ($_POST['id'] ?? 0); + $pdo->prepare('DELETE FROM departments WHERE id = :id')->execute(['id' => $id]); + add_flash('success', 'Department removed.'); + redirect('admin/departments.php'); + } + + $payload = [ + 'code' => strtoupper(trim($_POST['code'] ?? '')), + 'name' => trim($_POST['name'] ?? ''), + 'school_id' => (int) ($_POST['school_id'] ?? 0), + 'description' => trim($_POST['description'] ?? ''), + 'status' => (int) ($_POST['status'] ?? 1), + ]; + + if ($payload['code'] === '' || $payload['name'] === '') { + $errors[] = 'Department code and name are required.'; + } + + if (!$errors) { + if ($action === 'update') { + $payload['id'] = (int) ($_POST['id'] ?? 0); + $stmt = $pdo->prepare( + 'UPDATE departments SET code = :code, name = :name, school_id = :school_id, + description = :description, status = :status WHERE id = :id' + ); + $stmt->execute($payload); + add_flash('success', 'Department updated.'); + } else { + $stmt = $pdo->prepare( + 'INSERT INTO departments (code, name, school_id, description, status) + VALUES (:code, :name, :school_id, :description, :status)' + ); + $stmt->execute($payload); + add_flash('success', 'Department added.'); + } + + redirect('admin/departments.php'); + } + } +} + +$departments = $pdo->query( + 'SELECT d.*, s.name AS school_name + FROM departments d + LEFT JOIN schools s ON d.school_id = s.id + ORDER BY d.name ASC' +)->fetchAll(); + +render_header('Departments', ['active' => 'departments']); +?> +
+
+
+
Departments
+ total +
+
+ + + + +
+
+
+ +

No departments yet.

+ +
+ + + + + + + + + + + + + (int) $department['id'], + 'code' => $department['code'], + 'name' => $department['name'], + 'school_id' => (int) ($department['school_id'] ?? 0), + 'description' => $department['description'], + 'status' => (int) $department['status'], + ]); + ?> + + + + + + + + + +
CodeNameSchoolStatusActions
+ + + + + + +
+
+ +
+
+ + + + + + +query('SELECT id, name FROM activities ORDER BY date DESC')->fetchAll(); + +$filters = [ + 'start_date' => $_GET['start_date'] ?? date('Y-m-01'), + 'end_date' => $_GET['end_date'] ?? date('Y-m-d'), + 'activity_id' => $_GET['activity_id'] ?? '', + 'status' => $_GET['status'] ?? '', +]; + +$conditions = []; +$params = []; + +if ($filters['start_date']) { + $conditions[] = 'DATE(att.time_in) >= :start_date'; + $params['start_date'] = $filters['start_date']; +} + +if ($filters['end_date']) { + $conditions[] = 'DATE(att.time_in) <= :end_date'; + $params['end_date'] = $filters['end_date']; +} + +if ($filters['activity_id']) { + $conditions[] = 'att.activity_id = :activity_id'; + $params['activity_id'] = (int) $filters['activity_id']; +} + +if ($filters['status']) { + $conditions[] = 'att.status = :status'; + $params['status'] = $filters['status']; +} + +$where = $conditions ? 'WHERE ' . implode(' AND ', $conditions) : ''; +$stmt = $pdo->prepare( + "SELECT att.*, s.full_name, s.student_id, act.name AS activity_name + FROM attendance att + INNER JOIN students s ON att.student_id = s.id + INNER JOIN activities act ON att.activity_id = act.id + $where + ORDER BY att.time_in DESC" +); +$stmt->execute($params); +$records = $stmt->fetchAll(); + +render_header('Reports', ['active' => 'reports']); +?> +
+
+
Attendance Filters
+
+
+
+
+ + +
+
+ + +
+
+ + +
+
+ + +
+
+ +
+
+
+
+ +
+
+
Attendance Records
+ + Export JSON + +
+
+ +

No records match the filters.

+ +
+ + + + + + + + + + + + + + + + + + + + + + + +
StudentActivityStatusInOutNotes
+
+ +
+ + + +
+
+ +
+
+prepare( + 'INSERT INTO system_settings (setting_key, setting_value, description, updated_by) + VALUES (:key, :value, :description, :updated_by) + ON DUPLICATE KEY UPDATE setting_value = VALUES(setting_value), description = VALUES(description), + updated_by = VALUES(updated_by), updated_at = CURRENT_TIMESTAMP' + ); + foreach ($settings as $key => $data) { + $stmt->execute([ + 'key' => $key, + 'value' => $data['value'] ?? '', + 'description' => $data['description'] ?? '', + 'updated_by' => $userId, + ]); + } + add_flash('success', 'Settings updated.'); + redirect('admin/settings.php'); + } + + if ($action === 'create') { + $key = strtolower(trim($_POST['new_key'] ?? '')); + $value = trim($_POST['new_value'] ?? ''); + $description = trim($_POST['new_description'] ?? ''); + + if ($key === '') { + $errors[] = 'Setting key is required.'; + } else { + $stmt = $pdo->prepare( + 'INSERT INTO system_settings (setting_key, setting_value, description, updated_by) + VALUES (:key, :value, :description, :updated_by)' + ); + $stmt->execute([ + 'key' => $key, + 'value' => $value, + 'description' => $description, + 'updated_by' => $userId, + ]); + add_flash('success', 'Setting created.'); + redirect('admin/settings.php'); + } + } + } +} + +$settings = $pdo->query( + 'SELECT ss.*, u.full_name AS updated_by_name + FROM system_settings ss + LEFT JOIN users u ON ss.updated_by = u.id + ORDER BY ss.setting_key ASC' +)->fetchAll(); + +render_header('Settings', ['active' => 'settings']); +?> +
+
+
+
+
System Settings
+
+ + + +
+
+
+ +
+ +
+ +
+ + +

No settings found. Use the form on the right to add one.

+ +
+ + +
+ + + + + + + + + + + + + + + + + + + +
KeyValueDescriptionUpdated
+ + + + +
+ +
+
+
+ +
+
+ +
+
+
+
+
+
+
Add Setting
+
+
+
+ + +
+ + +
+
+ + +
+
+ + +
+ +
+
+
+
+
+query('SELECT id, code, name FROM courses WHERE status = 1 ORDER BY name')->fetchAll(); +$departments = $pdo->query('SELECT id, code, name FROM departments WHERE status = 1 ORDER BY name')->fetchAll(); +$genders = $pdo->query('SELECT id, name FROM genders ORDER BY id')->fetchAll(); +$schools = $pdo->query('SELECT id, name FROM schools WHERE status = 1 ORDER BY name')->fetchAll(); + +if (is_post()) { + if (!validate_csrf_token($_POST['csrf_token'] ?? null)) { + $errors[] = 'Invalid session token.'; + } else { + $action = $_POST['action'] ?? 'create'; + + if ($action === 'delete') { + $id = (int) ($_POST['id'] ?? 0); + $pdo->prepare('DELETE FROM students WHERE id = :id')->execute(['id' => $id]); + add_flash('success', 'Student removed.'); + redirect('admin/students.php'); + } + + $payload = [ + 'student_id' => trim($_POST['student_id'] ?? ''), + 'full_name' => trim($_POST['full_name'] ?? ''), + 'gender_id' => (int) ($_POST['gender_id'] ?? 0), + 'year_level' => (int) ($_POST['year_level'] ?? 1), + 'course_id' => (int) ($_POST['course_id'] ?? 0), + 'department_id' => (int) ($_POST['department_id'] ?? 0), + 'school_id' => (int) ($_POST['school_id'] ?? 0), + 'email' => trim($_POST['email'] ?? ''), + 'contact_number' => trim($_POST['contact_number'] ?? ''), + 'address' => trim($_POST['address'] ?? ''), + 'status' => (int) ($_POST['status'] ?? 1), + ]; + + if ($payload['student_id'] === '' || $payload['full_name'] === '') { + $errors[] = 'Student ID and full name are required.'; + } + + if (!$errors) { + if ($action === 'update') { + $payload['id'] = (int) ($_POST['id'] ?? 0); + $stmt = $pdo->prepare( + 'UPDATE students SET student_id = :student_id, full_name = :full_name, gender_id = :gender_id, + year_level = :year_level, course_id = :course_id, department_id = :department_id, + school_id = :school_id, email = :email, contact_number = :contact_number, + address = :address, status = :status + WHERE id = :id' + ); + $stmt->execute($payload); + add_flash('success', 'Student updated.'); + } else { + $qrToken = sprintf('STU-%s', strtoupper(random_token(6))); + $stmt = $pdo->prepare( + 'INSERT INTO students (student_id, full_name, gender_id, year_level, course_id, department_id, school_id, + email, contact_number, address, qr_code, status) + VALUES (:student_id, :full_name, :gender_id, :year_level, :course_id, :department_id, :school_id, + :email, :contact_number, :address, :qr_code, :status)' + ); + $stmt->execute(array_merge($payload, ['qr_code' => $qrToken])); + add_flash('success', 'Student registered.'); + } + + redirect('admin/students.php'); + } + } +} + +$pagination = paginate($pdo, 'SELECT COUNT(*) FROM students'); +$stmt = $pdo->prepare( + 'SELECT s.*, c.name AS course_name, d.name AS department_name + FROM students s + LEFT JOIN courses c ON s.course_id = c.id + LEFT JOIN departments d ON s.department_id = d.id + ORDER BY s.full_name ASC + LIMIT :limit OFFSET :offset' +); +$stmt->bindValue(':limit', $pagination['per_page'], PDO::PARAM_INT); +$stmt->bindValue(':offset', $pagination['offset'], PDO::PARAM_INT); +$stmt->execute(); +$students = $stmt->fetchAll(); + +render_header('Students', ['active' => 'students']); +?> +
+
+
+
Student Directory
+ Page of +
+
+ + + + +
+
+
+ +

No students yet.

+ +
+ + + + + + + + + + + + + + (int) $student['id'], + 'student_id' => $student['student_id'], + 'full_name' => $student['full_name'], + 'gender_id' => (int) $student['gender_id'], + 'year_level' => (int) $student['year_level'], + 'course_id' => (int) $student['course_id'], + 'department_id' => (int) $student['department_id'], + 'school_id' => (int) $student['school_id'], + 'email' => $student['email'], + 'contact_number' => $student['contact_number'], + 'address' => $student['address'], + 'status' => (int) $student['status'], + ]); + ?> + + + + + + + + + + +
StudentCourseDepartmentQR TokenStatusActions
+
+ +
+ + + + + + + + + +
+
+ + +
+
+ + + + + + + + + + strtolower(trim($_POST['username'] ?? '')), + 'full_name' => trim($_POST['full_name'] ?? ''), + 'email' => trim($_POST['email'] ?? ''), + 'role' => $_POST['role'] ?? 'admin', + 'password' => $_POST['password'] ?? '', + ]; + + if ($payload['username'] === '' || $payload['password'] === '' || $payload['full_name'] === '') { + $errors[] = 'Username, full name, and password are required.'; + } else { + $stmt = $pdo->prepare( + 'INSERT INTO users (username, password, role, full_name, email, status) + VALUES (:username, :password, :role, :full_name, :email, 1)' + ); + $stmt->execute([ + 'username' => $payload['username'], + 'password' => password_hash($payload['password'], PASSWORD_BCRYPT), + 'role' => $payload['role'], + 'full_name' => $payload['full_name'], + 'email' => $payload['email'], + ]); + add_flash('success', 'User account created.'); + redirect('admin/users.php'); + } + } + + if ($action === 'toggle') { + $id = (int) ($_POST['id'] ?? 0); + $stmt = $pdo->prepare('UPDATE users SET status = IF(status = 1, 0, 1) WHERE id = :id'); + $stmt->execute(['id' => $id]); + add_flash('success', 'User status updated.'); + redirect('admin/users.php'); + } + + if ($action === 'reset_password') { + $id = (int) ($_POST['id'] ?? 0); + $newPassword = trim($_POST['new_password'] ?? ''); + if ($newPassword === '') { + $errors[] = 'New password is required.'; + } else { + $stmt = $pdo->prepare('UPDATE users SET password = :password WHERE id = :id'); + $stmt->execute([ + 'password' => password_hash($newPassword, PASSWORD_BCRYPT), + 'id' => $id, + ]); + add_flash('success', 'Password updated.'); + redirect('admin/users.php'); + } + } + } +} + +$users = $pdo->query( + 'SELECT id, username, full_name, email, role, status, created_at + FROM users ORDER BY created_at DESC' +)->fetchAll(); + +render_header('Users', ['active' => 'users']); +?> +
+
+
+
Users
+ accounts +
+
+ + + + +
+
+
+ +

No users found.

+ +
+ + + + + + + + + + + + + + + + + + + + + + +
UserRoleStatusCreatedActions
+
+ · +
+ + + + +
+ + +
+
+
+ +
+
+ + + + + + + + + + false, 'message' => 'Student and activity are required.']); + exit; + } + + $studentStmt = $pdo->prepare( + 'SELECT * FROM students WHERE (student_id = :identifier OR qr_code = :identifier) LIMIT 1' + ); + $studentStmt->execute(['identifier' => $studentIdentifier]); + $student = $studentStmt->fetch(); + if (!$student) { + http_response_code(404); + echo json_encode(['success' => false, 'message' => 'Student not found.']); + exit; + } + + $activityStmt = $pdo->prepare('SELECT * FROM activities WHERE id = :id LIMIT 1'); + $activityStmt->execute(['id' => $activityId]); + $activity = $activityStmt->fetch(); + if (!$activity) { + http_response_code(404); + echo json_encode(['success' => false, 'message' => 'Activity not found.']); + exit; + } + + $now = (new DateTime())->format('Y-m-d H:i:s'); + $attendanceStmt = $pdo->prepare( + 'INSERT INTO attendance (student_id, activity_id, time_in, status, notes) + VALUES (:student_id, :activity_id, :time_in, :status, :notes) + ON DUPLICATE KEY UPDATE status = VALUES(status), notes = VALUES(notes), + updated_at = CURRENT_TIMESTAMP' + ); + $attendanceStmt->execute([ + 'student_id' => $student['id'], + 'activity_id' => $activityId, + 'time_in' => $now, + 'status' => $status, + 'notes' => $notes, + ]); + + $attendanceId = (int) $pdo->lastInsertId(); + if (!$attendanceId) { + $idLookup = $pdo->prepare( + 'SELECT id FROM attendance WHERE student_id = :student_id AND activity_id = :activity_id LIMIT 1' + ); + $idLookup->execute([ + 'student_id' => $student['id'], + 'activity_id' => $activityId, + ]); + $attendanceId = (int) $idLookup->fetchColumn(); + } + $log = $pdo->prepare( + 'INSERT INTO attendance_logs (attendance_id, action, old_value, new_value, changed_by, notes) + VALUES (:attendance_id, :action, :old_value, :new_value, :changed_by, :notes)' + ); + $log->execute([ + 'attendance_id' => $attendanceId, + 'action' => 'manual_entry', + 'old_value' => null, + 'new_value' => $now, + 'changed_by' => current_user()['id'], + 'notes' => $notes, + ]); + + echo json_encode(['success' => true, 'message' => 'Manual attendance recorded.']); + exit; +} + +// GET export +$filters = [ + 'start_date' => $_GET['start_date'] ?? null, + 'end_date' => $_GET['end_date'] ?? null, + 'activity_id' => $_GET['activity_id'] ?? null, + 'status' => $_GET['status'] ?? null, +]; + +$conditions = []; +$params = []; +if ($filters['start_date']) { + $conditions[] = 'DATE(att.time_in) >= :start_date'; + $params['start_date'] = $filters['start_date']; +} +if ($filters['end_date']) { + $conditions[] = 'DATE(att.time_in) <= :end_date'; + $params['end_date'] = $filters['end_date']; +} +if ($filters['activity_id']) { + $conditions[] = 'att.activity_id = :activity_id'; + $params['activity_id'] = (int) $filters['activity_id']; +} +if ($filters['status']) { + $conditions[] = 'att.status = :status'; + $params['status'] = $filters['status']; +} +$where = $conditions ? 'WHERE ' . implode(' AND ', $conditions) : ''; + +$stmt = $pdo->prepare( + "SELECT att.*, s.full_name, s.student_id, act.name AS activity_name + FROM attendance att + INNER JOIN students s ON att.student_id = s.id + INNER JOIN activities act ON att.activity_id = act.id + $where + ORDER BY att.time_in DESC" +); +$stmt->execute($params); + +header('Content-Type: application/json'); +echo json_encode($stmt->fetchAll()); diff --git a/src/api/scan.php b/src/api/scan.php new file mode 100644 index 0000000..2f0191c --- /dev/null +++ b/src/api/scan.php @@ -0,0 +1,137 @@ + false, 'message' => 'Invalid payload.']); + exit; +} + +$qrToken = trim($payload['qr_token'] ?? ''); +$activityId = (int) ($payload['activity_id'] ?? 0); +$notes = trim($payload['notes'] ?? ''); + +if ($qrToken === '' || !$activityId) { + http_response_code(422); + echo json_encode(['success' => false, 'message' => 'QR token and activity are required.']); + exit; +} + +$pdo = db(); + +$activityStmt = $pdo->prepare('SELECT * FROM activities WHERE id = :id AND status = 1 LIMIT 1'); +$activityStmt->execute(['id' => $activityId]); +$activity = $activityStmt->fetch(); + +if (!$activity) { + http_response_code(404); + echo json_encode(['success' => false, 'message' => 'Activity not found or inactive.']); + exit; +} + +$studentStmt = $pdo->prepare( + 'SELECT * FROM students WHERE (qr_code = :token OR student_id = :token) AND status = 1 LIMIT 1' +); +$studentStmt->execute(['token' => $qrToken]); +$student = $studentStmt->fetch(); + +if (!$student) { + http_response_code(404); + echo json_encode(['success' => false, 'message' => 'Student not found or inactive.']); + exit; +} + +$pdo->beginTransaction(); +try { + $attendanceStmt = $pdo->prepare( + 'SELECT * FROM attendance WHERE student_id = :student_id AND activity_id = :activity_id LIMIT 1' + ); + $attendanceStmt->execute([ + 'student_id' => $student['id'], + 'activity_id' => $activity['id'], + ]); + $attendance = $attendanceStmt->fetch(); + + $now = (new DateTime())->format('Y-m-d H:i:s'); + $action = ''; + + if (!$attendance) { + $insert = $pdo->prepare( + 'INSERT INTO attendance (student_id, activity_id, time_in, status, notes) + VALUES (:student_id, :activity_id, :time_in, :status, :notes)' + ); + $insert->execute([ + 'student_id' => $student['id'], + 'activity_id' => $activity['id'], + 'time_in' => $now, + 'status' => 'present', + 'notes' => $notes, + ]); + $attendanceId = (int) $pdo->lastInsertId(); + $action = 'time_in'; + } elseif ($attendance['time_out'] === null) { + $update = $pdo->prepare( + 'UPDATE attendance SET time_out = :time_out, notes = :notes, updated_at = CURRENT_TIMESTAMP + WHERE id = :id' + ); + $update->execute([ + 'time_out' => $now, + 'notes' => $notes ?: $attendance['notes'], + 'id' => $attendance['id'], + ]); + $attendanceId = (int) $attendance['id']; + $action = 'time_out'; + } else { + $pdo->rollBack(); + echo json_encode([ + 'success' => true, + 'message' => 'Attendance already completed for this student.', + 'meta' => [ + 'student' => $student['full_name'], + 'activity' => $activity['name'], + 'action' => 'ignored', + 'timestamp' => format_datetime($attendance['updated_at']), + ], + ]); + exit; + } + + $log = $pdo->prepare( + 'INSERT INTO attendance_logs (attendance_id, action, old_value, new_value, changed_by, notes) + VALUES (:attendance_id, :action, :old_value, :new_value, :changed_by, :notes)' + ); + $log->execute([ + 'attendance_id' => $attendanceId, + 'action' => $action, + 'old_value' => null, + 'new_value' => $now, + 'changed_by' => current_user()['id'], + 'notes' => $notes, + ]); + + $pdo->commit(); + + echo json_encode([ + 'success' => true, + 'message' => sprintf( + 'Marked %s for %s.', + $action === 'time_in' ? 'time in' : 'time out', + $student['full_name'] + ), + 'meta' => [ + 'student' => $student['full_name'], + 'activity' => $activity['name'], + 'action' => $action, + 'timestamp' => format_datetime($now), + ], + ]); +} catch (Throwable $exception) { + $pdo->rollBack(); + http_response_code(500); + echo json_encode(['success' => false, 'message' => 'Unable to record attendance.']); +} diff --git a/src/assets/css/style.css b/src/assets/css/style.css new file mode 100644 index 0000000..13b6230 --- /dev/null +++ b/src/assets/css/style.css @@ -0,0 +1,424 @@ +:root { + --brand-primary: #1b7f5c; + --brand-secondary: #3fc380; + --brand-accent: #a2d729; + --brand-muted: #edf6f0; + --bs-primary: var(--brand-primary); + --bs-primary-rgb: 27, 127, 92; + --bs-primary-bg-subtle: #d6f5ea; + --bs-primary-border-subtle: #a1dfc6; + --bs-link-color: var(--brand-primary); + --bs-link-hover-color: #146946; +} + +body { + background-color: #f2f9f4; + font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; + min-height: 100vh; +} + +.auth-shell { + width: 100%; + max-width: 100%; + margin: 0 auto; +} + +.google-auth-shell { + width: 100%; + min-height: calc(100vh - 4rem); + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + gap: 1.5rem; + padding: 2rem 1rem 3rem; + background: + radial-gradient(circle at top, rgba(66, 133, 244, 0.12), transparent 55%), + radial-gradient(circle at 20% 20%, rgba(52, 168, 83, 0.12), transparent 45%), + radial-gradient(circle at 80% 0%, rgba(234, 67, 53, 0.12), transparent 50%), + #f2f9f4; +} + +.google-auth-card { + background: #fff; + border-radius: 16px; + border: 1px solid rgba(218, 220, 224, 0.8); + padding: 2.75rem 3.25rem; + max-width: 460px; + width: 100%; + box-shadow: + 0 10px 30px rgba(26, 115, 232, 0.08), + 0 2px 8px rgba(0, 0, 0, 0.04); +} + +.google-auth-head .google-title { + font-weight: 500; +} + +.google-subtitle { + color: #5f6368; + font-size: 0.95rem; + margin: 0; +} + +.google-logo { + display: flex; + flex-direction: column; + align-items: center; + gap: 0.55rem; + margin-bottom: 0.75rem; +} + +.qr-logo-icon { + width: 64px; + height: 64px; + border-radius: 16px; + padding: 0.5rem; + background: linear-gradient(145deg, rgba(27, 127, 92, 0.12), rgba(15, 81, 50, 0.08)); + border: 1px solid rgba(27, 127, 92, 0.3); + display: inline-flex; + align-items: center; + justify-content: center; + box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35); +} + +.qr-logo-icon svg { + width: 100%; + height: 100%; +} + +.google-logo-text { + font-weight: 600; + font-size: 0.9rem; + color: #5f6368; +} + +.google-form { + display: flex; + flex-direction: column; +} + +.google-field { + position: relative; + margin-bottom: 1.5rem; + transition: transform 0.15s ease; +} + +.google-field:focus-within { + transform: translateY(-2px); +} + +.google-input { + width: 100%; + border: 1px solid #dadce0; + border-radius: 10px; + padding: 1.4rem 3rem 0.6rem 1rem; + background: transparent; + font-size: 1rem; + transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; +} + +.google-input:focus { + border-color: #1a73e8; + box-shadow: 0 6px 18px rgba(26, 115, 232, 0.15); + background: #fff; + outline: none; +} + +.google-input:not(:placeholder-shown) + .google-label, +.google-input:focus + .google-label { + top: 0.55rem; + font-size: 0.75rem; + color: #1a73e8; +} + +.google-label { + position: absolute; + left: 1rem; + top: 50%; + transform: translateY(-50%); + font-size: 0.95rem; + color: #5f6368; + transition: all 0.15s ease; + pointer-events: none; + background: #fff; + padding: 0 0.25rem; +} + +.google-toggle { + position: absolute; + top: 50%; + right: 0.75rem; + transform: translateY(-50%); + border: none; + background: transparent; + color: #1a73e8; + font-weight: 600; + font-size: 0.9rem; + padding: 0; + cursor: pointer; + transition: color 0.15s ease; +} + +.google-toggle:hover { + color: #174ea6; +} + +.google-links { + display: flex; + justify-content: flex-end; + font-size: 0.9rem; + margin-bottom: 2rem; +} + +.google-links a { + color: #1a73e8; + text-decoration: none; + font-weight: 600; +} + +.google-links a:hover { + text-decoration: underline; +} + +.google-actions { + display: flex; + justify-content: space-between; + align-items: center; + gap: 1rem; + margin-bottom: 1.5rem; +} + +.google-alt-action { + color: #1a73e8; + text-decoration: none; + font-weight: 600; + padding-left: 0; + padding-right: 0; + transition: color 0.15s ease; +} + +.google-alt-action:hover { + color: #174ea6; +} + +.google-primary-action { + min-width: 110px; + border-radius: 50px; + font-weight: 600; + background-color: #1a73e8; + border-color: #1a73e8; + box-shadow: 0 6px 18px rgba(26, 115, 232, 0.25); + transition: transform 0.15s ease, box-shadow 0.15s ease; +} + +.google-primary-action:hover { + background-color: #1668d8; + border-color: #1668d8; + transform: translateY(-1px); + box-shadow: 0 8px 24px rgba(26, 115, 232, 0.3); +} + +.google-footnote { + font-size: 0.85rem; + margin: 0; +} + +@media (max-width: 575.98px) { + .google-auth-card { + padding: 2rem; + border-radius: 12px; + } +} + +.app-shell { + display: flex; + min-height: 100vh; + background-color: #f5f7fb; +} + +.sidebar { + width: 260px; + padding: 2rem 1.5rem; + display: flex; + flex-direction: column; + flex-shrink: 0; + position: sticky; + top: 0; + height: 100vh; + overflow: hidden; + transition: all 0.25s ease; +} + +.sidebar-brand { + display: flex; + align-items: center; + gap: 0.75rem; +} + +.sidebar-icon { + width: 42px; + height: 42px; + border-radius: 12px; + display: grid; + place-items: center; + font-weight: 700; +} + +.sidebar-nav { + display: flex; + flex-direction: column; + gap: 0.25rem; +} + +.sidebar-link { + border-radius: 0.75rem; + padding: 0.65rem 0.85rem; + color: #495057; + text-decoration: none; + transition: all 0.15s ease; +} + +.sidebar-link:hover { + background-color: rgba(27, 127, 92, 0.1); + color: var(--brand-primary); +} + +.sidebar-link.active { + background-color: var(--brand-primary); + color: #fff; +} + +.sidebar-user { + display: flex; + align-items: center; + gap: 1rem; + padding: 0.75rem; + border-radius: 0.75rem; + background-color: var(--brand-muted); + border: 1px solid rgba(27, 127, 92, 0.15); +} + +.content-area { + display: flex; + flex-direction: column; + flex-grow: 1; + min-width: 0; + transition: margin-left 0.25s ease; +} + +.content-body { + flex-grow: 1; +} + +.camera-viewer { + min-height: 240px; + border: 1px dashed rgba(0, 0, 0, 0.15); + display: grid; + place-items: center; + overflow: hidden; +} + +body.sidebar-collapsed .sidebar { + width: 0; + padding: 0; + margin: 0; + opacity: 0; + pointer-events: none; +} + +body.sidebar-collapsed .content-area { + margin-left: 0; +} + +.sidebar-toggle { + border-radius: 999px; + width: 34px; + height: 34px; + display: grid; + place-items: center; + padding: 0; +} + +.navbar-brand { + color: var(--brand-primary) !important; +} + +.stat-card { + border: 1px solid rgba(0, 0, 0, 0.06); + border-radius: 1rem; + background: #fff; + padding: 1.5rem; + min-height: 130px; +} + +.stat-card h6 { + text-transform: uppercase; + letter-spacing: 0.08em; + font-size: 0.75rem; + color: #6c757d; + margin-bottom: 0.5rem; +} + +.stat-card .stat-value { + font-size: 2.25rem; + font-weight: 700; + color: var(--brand-primary); + margin: 0; +} + +.card { + border-radius: 1rem; + border-color: rgba(0, 0, 0, 0.05); +} + +.table thead { + background-color: var(--brand-muted); +} + +.badge-status { + text-transform: uppercase; + font-size: 0.7rem; + letter-spacing: 0.05em; +} + +.scan-panel { + background: linear-gradient(135deg, var(--brand-primary), var(--brand-secondary)); + color: #fff; + border-radius: 1.25rem; + padding: 2rem; + box-shadow: 0 20px 40px rgba(27, 127, 92, 0.25); +} + +.scan-panel h2 { + font-weight: 700; + margin-bottom: 1rem; +} + +.scan-panel .form-control, +.scan-panel .form-select { + border-radius: 0.75rem; +} + +.qr-preview { + border: 1px dashed rgba(0, 0, 0, 0.2); + border-radius: 1rem; + padding: 1rem; + background: #fff; +} + +.chip { + display: inline-flex; + align-items: center; + gap: 0.35rem; + padding: 0.35rem 0.85rem; + border-radius: 999px; + font-size: 0.75rem; + background-color: var(--brand-muted); + color: #1f5137; +} + +.text-muted-sm { + font-size: 0.9rem; + color: #868e96 !important; +} diff --git a/src/assets/images/aldersgate.png b/src/assets/images/aldersgate.png new file mode 100644 index 0000000..3a37d54 Binary files /dev/null and b/src/assets/images/aldersgate.png differ diff --git a/src/assets/js/admin.js b/src/assets/js/admin.js new file mode 100644 index 0000000..bb13108 --- /dev/null +++ b/src/assets/js/admin.js @@ -0,0 +1,175 @@ +(() => { + document.addEventListener('DOMContentLoaded', () => { + ['studentModal', 'activityModal', 'courseModal', 'departmentModal', 'userModal'] + .forEach(setupRecordModal); + setupSidebarToggle(); + setupQrModal('qrModal'); + ['deleteStudentModal', 'deleteActivityModal', 'deleteCourseModal', 'deleteDepartmentModal', 'toggleUserModal', 'resetPasswordModal'] + .forEach(setupDeleteModal); + }); + + function setupRecordModal(id) { + const modalEl = document.getElementById(id); + if (!modalEl) return; + + const createTitle = modalEl.dataset.createTitle || 'Add Record'; + const editTitle = modalEl.dataset.editTitle || 'Edit Record'; + const createSubmit = modalEl.dataset.createSubmit || 'Add Record'; + const editSubmit = modalEl.dataset.editSubmit || 'Save Changes'; + + modalEl.addEventListener('show.bs.modal', (event) => { + const button = event.relatedTarget; + const mode = button && button.dataset ? button.dataset.mode || 'create' : 'create'; + const form = modalEl.querySelector('form'); + if (!form) return; + const hasRecordPayload = Boolean(button && button.dataset && button.dataset.record); + const isEdit = mode === 'edit' || hasRecordPayload; + + form.reset(); + form.querySelector('[name="action"]').value = isEdit ? 'update' : 'create'; + form.querySelector('[name="id"]').value = ''; + + const title = modalEl.querySelector('[data-modal-title]'); + const submit = modalEl.querySelector('[type="submit"]'); + + if (hasRecordPayload) { + try { + const data = JSON.parse(atob(button.dataset.record)); + Object.entries(data).forEach(([key, value]) => { + const field = form.querySelector(`[name="${key}"]`); + if (!field) return; + field.value = value ?? ''; + }); + form.querySelector('[name="id"]').value = data.id ?? ''; + } catch (error) { + console.error('Failed to parse record payload', error); + } + } + + if (title) { + title.textContent = isEdit ? editTitle : createTitle; + } + if (submit) { + submit.textContent = isEdit ? editSubmit : createSubmit; + } + }); + } + + function setupSidebarToggle() { + const toggleButtons = document.querySelectorAll('[data-sidebar-toggle]'); + if (!toggleButtons.length) return; + + const storageKey = 'sidebarCollapsed'; + if (localStorage.getItem(storageKey) === '1') { + document.body.classList.add('sidebar-collapsed'); + } + + toggleButtons.forEach((button) => { + button.addEventListener('click', () => { + document.body.classList.toggle('sidebar-collapsed'); + const collapsed = document.body.classList.contains('sidebar-collapsed'); + localStorage.setItem(storageKey, collapsed ? '1' : '0'); + }); + }); + } + + function setupQrModal(id) { + const modalEl = document.getElementById(id); + if (!modalEl) return; + + const generator = modalEl.getAttribute('data-generator') || ''; + const nameEl = modalEl.querySelector('[data-qr-name]'); + const idEl = modalEl.querySelector('[data-qr-id]'); + const tokenEl = modalEl.querySelector('[data-qr-token]'); + const imageEl = modalEl.querySelector('[data-qr-image]'); + const downloadEl = modalEl.querySelector('[data-qr-download]'); + + modalEl.addEventListener('show.bs.modal', (event) => { + const trigger = event.relatedTarget; + if (!trigger || !trigger.dataset) return; + + const token = trigger.dataset.qrToken || ''; + const studentId = trigger.dataset.studentId || ''; + const studentName = trigger.dataset.studentName || 'Student'; + + if (nameEl) nameEl.textContent = studentName; + if (idEl) idEl.textContent = `ID: ${studentId || '—'}`; + if (tokenEl) tokenEl.textContent = token; + + if (imageEl) { + if (generator && token) { + imageEl.src = `${generator}?token=${encodeURIComponent(token)}&v=${Date.now()}`; + imageEl.alt = `QR code for ${studentName}`; + } else { + imageEl.removeAttribute('src'); + imageEl.alt = 'QR code unavailable'; + } + } + + if (downloadEl) { + const canDownload = Boolean(generator && token); + if (canDownload) { + downloadEl.href = `${generator}?token=${encodeURIComponent(token)}&download=1`; + downloadEl.setAttribute('download', `qr-${studentId || token}.png`); + downloadEl.classList.remove('disabled'); + downloadEl.removeAttribute('aria-disabled'); + } else { + downloadEl.href = '#'; + downloadEl.setAttribute('aria-disabled', 'true'); + downloadEl.classList.add('disabled'); + } + } + }); + } + + function setupDeleteModal(id) { + const modalEl = document.getElementById(id); + if (!modalEl) return; + + const nameEl = modalEl.querySelector('[data-delete-name]'); + const idEl = modalEl.querySelector('[data-delete-id]'); + const messageEl = modalEl.querySelector('[data-delete-message]'); + const confirmButton = modalEl.querySelector('[data-delete-confirm]'); + const hiddenId = modalEl.querySelector('input[name="id"]'); + const defaultNameText = nameEl ? nameEl.textContent : 'Record Name'; + const defaultIdText = idEl ? idEl.textContent : ''; + const defaultMessageText = messageEl ? messageEl.textContent : ''; + const defaultConfirmText = confirmButton ? confirmButton.textContent : ''; + + modalEl.addEventListener('show.bs.modal', (event) => { + const trigger = event.relatedTarget; + if (!trigger || !trigger.dataset) return; + + const recordId = trigger.dataset.id || ''; + const recordName = trigger.dataset.recordName || trigger.dataset.studentName || 'Record'; + const recordRef = trigger.dataset.recordRef || trigger.dataset.studentId || ''; + + if (hiddenId) hiddenId.value = recordId; + if (nameEl) nameEl.textContent = recordName || defaultNameText; + if (idEl) { + if (recordRef) { + const label = idEl.dataset.label || ''; + idEl.textContent = label ? `${label}: ${recordRef}` : recordRef; + } else { + idEl.textContent = defaultIdText; + } + } + if (messageEl) { + const confirmText = trigger.dataset.confirmText || ''; + messageEl.textContent = confirmText || defaultMessageText; + } + if (confirmButton) { + const confirmLabel = trigger.dataset.confirmLabel || ''; + confirmButton.textContent = confirmLabel || defaultConfirmText; + } + }); + + modalEl.addEventListener('hidden.bs.modal', () => { + if (hiddenId) hiddenId.value = ''; + if (nameEl) nameEl.textContent = defaultNameText; + if (idEl) idEl.textContent = defaultIdText; + if (messageEl) messageEl.textContent = defaultMessageText; + if (confirmButton) confirmButton.textContent = defaultConfirmText; + }); + } +})(); diff --git a/src/assets/js/scan.js b/src/assets/js/scan.js new file mode 100644 index 0000000..bb01205 --- /dev/null +++ b/src/assets/js/scan.js @@ -0,0 +1,223 @@ +(() => { + document.addEventListener('DOMContentLoaded', () => { + const scanForm = document.querySelector('[data-scan-form]'); + if (scanForm) { + const endpoint = scanForm.dataset.endpoint; + const qrInput = scanForm.querySelector('input[name="qr_token"]'); + const resultBox = document.querySelector('#scan-result'); + const statusBox = document.querySelector('#scan-status'); + const submitBtn = scanForm.querySelector('button[type="submit"]'); + const setStatus = (message, classes = 'text-white fw-semibold') => { + if (!statusBox) return; + statusBox.textContent = message; + statusBox.className = classes; + }; + + scanForm.addEventListener('submit', async (event) => { + event.preventDefault(); + if (!endpoint) return; + + const payload = Object.fromEntries(new FormData(scanForm)); + submitBtn.disabled = true; + setStatus('Processing scan…'); + + try { + const response = await fetch(endpoint, { + method: 'POST', + headers: { + 'Content-Type': 'application/json', + 'X-Requested-With': 'XMLHttpRequest' + }, + body: JSON.stringify(payload) + }); + + const data = await response.json(); + setStatus( + data.message || 'No response message', + data.success ? 'text-success fw-semibold' : 'text-danger fw-semibold' + ); + + if (data.meta && resultBox) { + resultBox.innerHTML = ` +
+
+ Student: ${data.meta.student ?? '—'} +
+
+ Activity: ${data.meta.activity ?? '—'} +
+
+ Action: ${data.meta.action ?? '—'} +
+
+ Recorded: ${data.meta.timestamp ?? '—'} +
+
+ `; + } + + qrInput.value = ''; + qrInput.focus(); + } catch (error) { + console.error(error); + setStatus('Unable to process scan. Please try again.', 'text-danger fw-semibold'); + } finally { + submitBtn.disabled = false; + } + }); + + setupCameraScanner(scanForm, qrInput, setStatus); + } + }); + + function setupCameraScanner(form, qrInput, setStatus) { + const cameraRegion = document.querySelector('#camera-viewer'); + const startButton = document.querySelector('[data-scan-start]'); + if (!cameraRegion || !startButton) return; + + let html5Scanner = null; + let fallbackController = null; + + startButton.addEventListener('click', async () => { + if (startButton.dataset.state === 'running') { + await stopScanner(); + return; + } + + startButton.disabled = true; + setStatus('Initializing camera scanner…'); + const started = await startScanner(); + startButton.disabled = false; + + if (!started) { + startButton.classList.add('disabled'); + cameraRegion.innerHTML = '
Camera scan unavailable in this browser.
'; + setStatus('Camera scan unavailable. Please type QR token manually.', 'text-warning fw-semibold'); + } + }); + + async function startScanner() { + if (window.Html5Qrcode) { + return startHtml5Scanner(); + } + if ('BarcodeDetector' in window) { + fallbackController = await startFallbackScanner(); + if (fallbackController) { + startButton.dataset.state = 'running'; + startButton.textContent = 'Stop Camera Scan'; + setStatus('Camera scanner ready (fallback mode).'); + return true; + } + } + return false; + } + + async function startHtml5Scanner() { + try { + if (!html5Scanner) { + html5Scanner = new Html5Qrcode(cameraRegion.id); + } + cameraRegion.innerHTML = ''; + await html5Scanner.start( + { facingMode: 'environment' }, + { fps: 10, qrbox: 240 }, + (decodedText) => { + if (!decodedText) { + return; + } + qrInput.value = decodedText.trim(); + form.requestSubmit(); + stopScanner(); + }, + () => {} + ); + startButton.dataset.state = 'running'; + startButton.textContent = 'Stop Camera Scan'; + setStatus('Camera scanner ready (high fidelity).'); + return true; + } catch (error) { + console.error(error); + await stopScanner(); + setStatus('Camera scanner could not start. Trying fallback…', 'text-warning fw-semibold'); + return false; + } + } + + async function stopScanner() { + if (html5Scanner) { + await html5Scanner.stop().catch(() => {}); + html5Scanner.clear(); + html5Scanner = null; + } + if (fallbackController) { + fallbackController.stop(); + fallbackController = null; + } + startButton.dataset.state = ''; + startButton.textContent = 'Start Camera Scan'; + cameraRegion.innerHTML = '
Camera idle
'; + startButton.classList.remove('disabled'); + setStatus('Camera idle. Ready for manual scans.', 'text-white-50 fw-semibold'); + } + + async function startFallbackScanner() { + let stream; + let detector; + let detectionTimer; + const video = document.createElement('video'); + video.className = 'w-100 rounded'; + video.setAttribute('playsinline', 'true'); + video.muted = true; + cameraRegion.innerHTML = ''; + cameraRegion.appendChild(video); + + try { + detector = new BarcodeDetector({ formats: ['qr_code'] }); + stream = await navigator.mediaDevices.getUserMedia({ video: { facingMode: 'environment' } }); + video.srcObject = stream; + await video.play(); + + const scanFrame = async () => { + if (!detector) return; + try { + const codes = await detector.detect(video); + if (codes.length > 0) { + qrInput.value = codes[0].rawValue.trim(); + form.requestSubmit(); + stop(); + return; + } + } catch (error) { + console.error(error); + } + detectionTimer = requestAnimationFrame(scanFrame); + }; + + detectionTimer = requestAnimationFrame(scanFrame); + } catch (error) { + console.error(error); + stop(); + setStatus('Fallback scanner unavailable. Please allow camera access.', 'text-warning fw-semibold'); + return null; + } + + function stop() { + if (detectionTimer) { + cancelAnimationFrame(detectionTimer); + detectionTimer = null; + } + if (stream) { + stream.getTracks().forEach((track) => track.stop()); + stream = null; + } + if (video.srcObject) { + video.pause(); + video.srcObject = null; + } + detector = null; + } + + return { stop }; + } + } +})(); diff --git a/src/auth/login.php b/src/auth/login.php new file mode 100644 index 0000000..07e0438 --- /dev/null +++ b/src/auth/login.php @@ -0,0 +1,122 @@ + true]); +?> +
+
+ Admin Portal +

Use your institution-issued credentials to continue.

+
+
+
+ +

Sign in

+

Use your administrator account

+
+ +
+ +
+ +
+ +
+ +
+ + +
+
+ + + +
+ +
+ + +
+
+

+ This console is managed by IT. By continuing, you agree to internal security policies. +

+
+
+ + + []]); diff --git a/src/auth/logout.php b/src/auth/logout.php new file mode 100644 index 0000000..a7f036e --- /dev/null +++ b/src/auth/logout.php @@ -0,0 +1,6 @@ + [ + 'name' => getenv('APP_NAME') ?: 'QR Attendance System', + 'timezone' => getenv('APP_TZ') ?: 'Asia/Manila', + 'base_url' => rtrim(getenv('APP_BASE_URL') ?: '', '/'), + ], + 'db' => [ + 'host' => getenv('DB_HOST') ?: '127.0.0.1', + 'port' => getenv('DB_PORT') ?: '3306', + 'name' => getenv('DB_NAME') ?: 'attendance_system', + 'user' => getenv('DB_USER') ?: 'root', + 'pass' => getenv('DB_PASS') ?: '', + 'charset' => 'utf8mb4', + ], + 'qr' => [ + 'provider' => strtolower(getenv('QR_PROVIDER') ?: 'auto'), + 'goqr_size' => getenv('QR_SIZE') ?: '300x300', + ], +]; diff --git a/src/d4c.zip b/src/d4c.zip new file mode 100644 index 0000000..05c6bbf Binary files /dev/null and b/src/d4c.zip differ diff --git a/src/includes/auth.php b/src/includes/auth.php new file mode 100644 index 0000000..fa04aca --- /dev/null +++ b/src/includes/auth.php @@ -0,0 +1,73 @@ +prepare('SELECT * FROM users WHERE username = :username AND status = 1 LIMIT 1'); + $stmt->execute(['username' => $username]); + $user = $stmt->fetch(); + + if (!$user) { + return false; + } + + if (!password_verify($password, $user['password'])) { + return false; + } + + $_SESSION['user'] = [ + 'id' => $user['id'], + 'username' => $user['username'], + 'full_name' => $user['full_name'], + 'role' => $user['role'], + 'email' => $user['email'], + ]; + + return true; +} + +function logout_user(): void +{ + $_SESSION = []; + if (ini_get('session.use_cookies')) { + $params = session_get_cookie_params(); + setcookie( + session_name(), + '', + time() - 42000, + $params['path'], + $params['domain'], + $params['secure'], + $params['httponly'] + ); + } + session_destroy(); +} diff --git a/src/includes/bootstrap.php b/src/includes/bootstrap.php new file mode 100644 index 0000000..0e8500a --- /dev/null +++ b/src/includes/bootstrap.php @@ -0,0 +1,16 @@ + PDO::ERRMODE_EXCEPTION, + PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, + ] + ); + } + + return $pdo; +} diff --git a/src/includes/helpers.php b/src/includes/helpers.php new file mode 100644 index 0000000..8e64c72 --- /dev/null +++ b/src/includes/helpers.php @@ -0,0 +1,219 @@ +format($format); +} + +function format_date(?string $value, string $format = 'M d, Y'): string +{ + if (!$value) { + return '—'; + } + $date = new DateTime($value); + + return $date->format($format); +} + +function selected(mixed $current, mixed $value): string +{ + return (string) $current === (string) $value ? 'selected' : ''; +} + +function checked(bool $condition): string +{ + return $condition ? 'checked' : ''; +} + +function paginate(PDO $pdo, string $countSql, array $params = [], int $perPage = 10): array +{ + $page = max(1, (int) ($_GET['page'] ?? 1)); + $stmt = $pdo->prepare($countSql); + $stmt->execute($params); + $total = (int) $stmt->fetchColumn(); + $pages = max(1, (int) ceil($total / $perPage)); + $page = min($page, $pages); + $offset = ($page - 1) * $perPage; + + return [ + 'page' => $page, + 'per_page' => $perPage, + 'total' => $total, + 'pages' => $pages, + 'offset' => $offset, + ]; +} + +function render_pagination(array $pagination, string $basePath = '', array $query = []): void +{ + if (($pagination['pages'] ?? 1) <= 1) { + return; + } + + $base = $basePath ?: parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH); + ?> + + + + + + + + <?= sanitize($title) ?> | <?= sanitize($appName) ?> + + + + + + + + +
+ +
+ +
+
+
+ +
QR Attendance System
+

+
+ +
+
+ + $messages): ?> + + + + + + +
+ +
+