Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge develop back to Master for a new release. (#493)
Merging the feature branch (PHP 7.2 compatibility) back to master. * toggle quickactionmenu visibility by clicking it * Candidate duplicates module added and integrated with other modules * corrected header of file to follow license * duplicates module integrated into candidates module and added access level checks for duplicate functions * added duplicates quick action menu * quickaction for duplicates added * rename of DuplicateCandidate to CandidateDuplicate * tag fix * quickaction fixes * acl related refactoring ifor duplicates * fixed typo error * fixed typo error * fixed duplicate quick action menu - added permissions and access level * fixed duplicate quick action menu - added permissions and access level * removing duplicate info from function parameters * adjusting candidate datagrid * removing unnecessary duplicate code * adding includes * added duplicate info into candidate show page * config update * changed duplicate secure object names * removed unused template * db upgrade, not tested * updated migration from 0.9.4 to 0.9.5 * added duplicate db table to test db * correction in javascript based on codacy review * js code fixes based on codacy review * removed forgotten or badly merged parameter from a function * duplicate initialization * fixed (hopefully well) duplicate primary key errors during update by using delete and insert ignore * add ckeditor to composer * updated reference to ckeditor in tpl files * removed embedded ckeditor files * added legacy_root into includes, defined in config.php * added legacy root into tests * missing legacy_root added * small typo fixes in Legacy root usage * added duplicate candidate icon to pipeline grids * fixed duplicate rows after merge of candidate pipeline details and history * fixed some logical errors and added input trim and whitespace removal to phone numbers * removed unused function * removed old todo * fixed list entry duplicates in duplicate merge and moved it into separate functions * fixed missing access level * added URI encoding to AJAX call so "&" can be a part of a list name, not taken as a new URI parameter and thrown away (#251) * Added a Public/Private column into job order datagrid (#239) * updated import * Ckeditor font plugin only where needed (#229) * font plugin moved to instantiation of ckeditor * remove duplicated code by extracting a common method * travis build fix * added indexes to duplicates table * Job order import (#230) * added class JobOrderImport * added options for job order import * added job order import into ImportUI * fix in importUI to use joborder not candidate * added import_id into job order import so that it can be reverted * added import_id into job order import also in test.sql database * added migration script * Email templates support (#231) * get, add, delete, update email templates lib changes * Add/Delete template in template manager * Add/Delete/Update template in SettingsUI * new ajax functions to choose an email template and to preview how it'll look like for each candidate * new ajax calls for emails * send emails in bulk when not using template, send by one when using it * getting neccesary info from db * added js lib * added fields to email form * disabled checking of empty email body, ckeditor had problems with it * preview css changes * add comment to unused code * files reformat * single quotes to double quotes and changed order of functions (based on codacy review) * codacy review comments applied and format changes * further change based on codacy review * code cleanup * Update db/cats_testdata.bak (#398) Updated sample OpenCATS test data for MySQL; - strict mode compliant (now the default), and; - added in candidate_tag tables to MySQL table structure Installer does not error now when you select the demonstration data. Resolves ancient issue #9 * Revert "Update db/cats_testdata.bak (#398)" (#399) This reverts commit 7f4b669. * Update db/cats_testdata.bak (#400) Updated test data for MySQL; - strict mode compliant (now the default), and; - added in candidate_tag tables to MySQL table structure Installer does not error now when you select the demonstration data. * Job order statuses configurable (#236) * changes in variable name * new class for job order statuses * new status configuration in config * replacing hard coded statuses/filters with ones from config/default * removing mention of free version of opencats and replacing hardcoded statuses with ones from config * hardcoded statuses to config Open statuses * removed never used code/constants and replacing one mention with config statuses * replaced hardcoded statuses with equivalent Open statuses from config * replacing hardcoded default filter with the first one from config * creating job order from existing one extended for job orders of all statuses * changing JobOrderStatuses to static class * altered default job order status in db to 'New', it should never be used though because in next commit a default new job order status from config or JobOrderStatuses class shall be used * added default new job order status to code, didn't leave it to database to set its default * added new job status const to config * changed config statuses to correspond with the old ones * database default status revert * config status variables renaming * added config info into class * variable/method renaming * method rename * commented examples in config.php * added include * 16 chars is not enough for status, e.g. 'Candidate selected' is longer * Corrected Lead status (not prospective) * merge error fixed * Import of files in different encoding (#238) * added input file encoding to import, so we can convert it to UTF-8 if necessary * encoding option won't show if the config variable is missing or empty * fixed method comment * renamed file to its class name and because there were two Import.php files already * split modules/import/Import.php file into more files by classes, created an abstract parent class and kept only 'add' functions in child classes * Whats left of modules/import/Import.php * moved one function to Companies because it was duplicated in CompaniesImport and ContactsImport classes and shouldnt be in their parent class * fixed/added includes * removed encoding from import code to replace it somewhere else * moved file encoding closer to file upload, commented out config options because they are not all supported * removed duplicate definitions of import classes * Pipeline in GUI changed to Job Order or Candidates based on context where it is displayed. (#243) tested locally, seems intuitive, can revert if issues. * Fix state location mapping (#245) * Fix state location mapping Replace administrative_area_level_2 which returns the county with administrative_area_level_1 which returns the state (expected). * Update ZipLookup.php Set return address values based on US vs non-US lookup location * updated travis.yml to add in php 7.3 testing * updated travis.yml to remove php 7.3 testing Thought I could run testing for both versions - but i'll have ot have a separate branch; need to specify a different version of phpunit for php7.x * Spelling Vetran -> Veteran * Spelling Vetran -> Veteran * Resolved issue #444 - rss is not valid (#447) - Further analyzing the project source code for the use of getRSSDate(), it is confirmed that the call should be made statically, as CATSUtility::getAbsoluteURI() is done. - To resolve the issue we needed to correct the function’s signature declaration in OpenCATS/lib/DateUtility.php, as such: - Added the “static” property at the beginning of the function signature line 350, as such: - static public function getRSSDate($unixTime = false) * Closing out the 'test-php-7' feature branch and merging back to develop (#420) * Fixed #171 Used mysqli procedural methods instead of mysql methods. This is a quick fix to make OpenCATS compatible with PHP7. * Updated mysql extension in docker config * Fix insecure SMTP (#357) A past phpmailer update changed to assume to use TLS even if its not enabled. This breaks insecure SMTP connections. * Fix deprecated PHP4-style constructors (#358) In some cases the file name implies it's for use with PHP4 which probably doesn't work anymore. I changed those too so there isn't noise in php7cc output * Gate set_magic_quotes_runtime calls Function was removed in PHP 7. Versions of PHP where this functionality exists are theoretically not supported and these calls could be removed entirely instead of placed behind function_exists() checks * Validate emails with filter_var() instead of eregi() The ereg functions were removed in PHP 7. In this specific use case filter_var() seems like a better solution than migrating to a preg regex. * Replace ereg functions with preg functions erege functions were removed in PHP 7. FPDF has the same patch upstream; artichow doesn't appear to have been updated upstream. * Use explode() instead of split() split() was removed in PHP 7. Code was simply splitting on different single character delimiters so using explode() instead works fine. * Don't combine `&` and `new` operators This is a syntax error in PHP 7. It's been deprecated for a long time so this change probably has no impact on behavior * Updated issue template to be more specific * Update issue_template.md * config file for the ProBot no-response bot add the tag more-information-required to issues, if no response then will auto-close in 14 days. * Update no-response.yml * Updated test data for MySQL; - strict mode compliant (now the default), and; - added in candidate_tag tables to MySQL table structure Installer does not error now when you select the demonstration data. * Revert "Updated test data for MySQL;" This reverts commit 2ce655a. * Update modules/settings/SettingsUI.php Co-Authored-By: gohanman <[email protected]> * $co$conn is presumably a typo * Correct mysqli_select_db argument order * Missing paren in mysqli refactor * Use MYSQLI_ASSOC consistently * Update travis.yml for php 7.3 checks exclusively * revised composer.json to require php v7 * Fix the PHP7 build in travis (#419) * Rename composer.lock to ~composer.lock * revert custom php image to generic * Update .travis.yml * Update .travis.yml * revert custom php image * Update docker-compose-test.yml * Update docker-compose.yml * Update docker-compose.yml * Update docker-compose.yml * Update docker-compose-test.yml * Update docker-compose-test.yml * Update docker-compose.yml * Update docker-compose.yml * Update docker-compose-test.yml * Update docker-compose.yml * Update docker-compose-test.yml * Rename ~composer.lock to composer.lock * Update .travis.yml * Update .travis.yml * pointed to russh dockerhub image for php 7.2 * update travis to use php 7.2 * Rename composer.lock to composer.lock_OFF * tracking composer.lock for php 7.2 * updated target for php to be 7.2-fpm-alpine * fixed typos * remove redundant filew * test fix for travis build errors * simple rename php5 -> php7 in user instructions * quick update to address XXE vulnerability * New set of fixes for PHP 7.2 (#429) * Updated PHPMailer to support PHP 7.2 - PHPMailer 5.2 is no longer supported. - Legacy PHPMailer, which was under /lib didn't support PHP 7 best practices. - Removed /lib/PHPMailer directory. - Updated /lib/Mailer.php to support the new PHPMailer v6. - Updated code to support PHPMailer v6. - Tested the work locally and works fine. * Resolved mysqli_error() handling by leveraging provided and tested PHP library function utilities. - Where mysqli_connect was verified, I simplified and replaced error handling with with mysqli_connect_errno() and mysqli_connect_error(). - Where query request was verified, I simplified and replaced error handling with queryResult->connect_errno() and queryResult->connect_error(). * Added .DS_Store file in .gitignore - Specified common Mac OS specific .DS_Store file to be ignored by git. * Added codacy/coverage vendor library to the project's Composer dev dependencies list. * Resolved issue with non-static method calls, as such: - Corrected DatabaseSearch's fulltextDecode() and fulltextEncord() methods' signatures to be static. - Corrected Contacts' getDepartmentIDByName() method call. Since, it was used differently multiple places. * Resolved issue related to innaccessible property, as such: - Reinforced query result object property existance check with isset(). * Resolved issue around referencing a non-existing scope property, as such: - Replaced $sql with $this to correctly access class properties. * Artichow - Resolved graph generation issue with PHP 7.2 - Label.class.php was complaining about count() param (texts) not being an array. Variable value needed to be verified prior the call to count(). - Label.class.php and Axis.class.php were complaining about function name was malformed for eval() to handle. microtime() needed to be carefully handled. * Updated .gitignore to dismiss /vendor folder, which get generated by composer. * Sphinx Search fixes for PHP 7.2 - Resolved deprecated create_function() by replacing with closure/anonymous function in Search.php. - Resolved count() complaining about $this->_rs not being an array in Search.php on line 2091. - Resolved by creating sphinx.conf to support newer Sphinx 2.2.4+ features. - Resolved by creating the missing required folders for Sphinx use. * Fixed #451 there was an issue with the installer, this was an issue with the the mysqli call that now now changed how errors number and error descriptions are captured * Revert "Fixed #451 there was an issue with the installer, this was an issue with the the mysqli call that now now changed how errors number and error descriptions are captured" This reverts commit a924d08. * Fixed #451 there was an issue with the installer, this was an issue with the the mysqli call that now now changed how errors number and error descriptions are captured * Two (2) Fixes - Resolved issue #444 + A missing class reference (#456) * Resolved issue #444 - rss is not valid - Further analyzing the project source code for the use of getRSSDate(), it is confirmed that the call should be made statically, as CATSUtility::getAbsoluteURI() is done. - To resolve the issue we needed to correct the function’s signature declaration in OpenCATS/lib/DateUtility.php, as such: - Added the “static” property at the beginning of the function signature line 350, as such: - static public function getRSSDate($unixTime = false) * Resolve issue with missing class reference to JobOrderStatuses which is used on line 1028 of Search.php as JobOrderStatuses::getOpenStatusSQL(). * Update ActivityEntries.php (#450) minor change updates activity list for candidates to show most recent activity first. Previous behaviour shows oldest activity first. * Update mailer.php to support umlauts (enforce UTF-8) (#449) Submitted on behalf of @dveos from https://forums.opencats.org/viewtopic.php?f=4&t=1509 * added job reference number to pipeline datagrid on candidate show page (#268) * Show 'lists' on candidates page (#269) * added table to candidate show page to display lists where candidate belongs * sending lists to template * added lib function to get list names and ids for given candidate id * fix LDAP module (#366) * added activity logging after adding new candidate (#270) * added the option to email a candidate from the candidate show page (it was already implemented through mailto:, but this option is through OpenCATS so the email templates can be used) (#246) (#457) * Revert "added the option to email a candidate from the candidate show page (it was already implemented through mailto:, but this option is through OpenCATS so the email templates can be used) (#246) (#457)" This reverts commit 0cd2295. * PHP7 Test build and tag (#461) * fix package generation * updated secure api_key value for travis-ci * Update .travis.yml * adding php version currently under active support tot the test matrix (#465) * adding php version currently under active support Adding missing closing tag * bumping docker compose to , fixing php 7.4 decprecation warnings * Update the encrypted secure api_key for Travis CI to generate releases. * Develop (#473) * Resolved issue #444 - rss is not valid - Further analyzing the project source code for the use of getRSSDate(), it is confirmed that the call should be made statically, as CATSUtility::getAbsoluteURI() is done. - To resolve the issue we needed to correct the function’s signature declaration in OpenCATS/lib/DateUtility.php, as such: - Added the “static” property at the beginning of the function signature line 350, as such: - static public function getRSSDate($unixTime = false) * Resolve issue with missing class reference to JobOrderStatuses which is used on line 1028 of Search.php as JobOrderStatuses::getOpenStatusSQL(). * Resolved an issue with MySQL fetch command failing due to empty record set. Safeguarding MySQL function call. * Resolved an issue with SQL logic failing to safe keyword 'system'. Safeguarded by wrapping the keyword 'system' with backtick marks. * Resolved issue with limited character space for site source URL that may contain long query strings. * Updated OpenCATS version * Resolved outdated artichow library related functional issues. * Changed the organization's UI visible copyright statement to show OpenCAT. * Travis.yml validation (#492) * update travis.yml after yml validation - corrected syntax error * Update Mailer.php - corrected syntax error Co-authored-by: Kristina Odziomkova <[email protected]> Co-authored-by: skrchnavy <[email protected]> Co-authored-by: SvetoKrchnavy <[email protected]> Co-authored-by: Sveto Krchnavy <[email protected]> Co-authored-by: Matias Lespiau <[email protected]> Co-authored-by: Sveto Krchnavy <[email protected]> Co-authored-by: smackjack3 <[email protected]> Co-authored-by: Shant Adam <[email protected]> Co-authored-by: amaisonneuve <[email protected]> Co-authored-by: Alain Maisonneuve <[email protected]> Co-authored-by: wumb0 <[email protected]> Co-authored-by: Bram Vogelaar <[email protected]>
- Loading branch information