0
Résultats de validation

Charity Hub

Charity Hub

WordPress 6.7 theme
0
  • TYPE DE THèMEThème WordPress %s 6.7
  • NOM DU FICHIERthemeforest-7481543-charity-hub-charity-nonprofit-fundraising-wp-wordpress-theme.zip
  • TAILLE DU FICHIER25319021 octets
  • MD5ecbba142514cba890563f56d43d768f7
  • SHA160a7467a75aea648753685d5d85444a247c32833
  • LICENCEAucun
  • FICHIERS INCLUSCSS, PHP, Bitmap images
  • URI DU THèME URIhttp://themes.goodlayers2.com/charityhub
  • VERSION1.31
  • URI DE L'AUTEUR
  • TAGSwhite, light, Green, two-columns, fluid-layout, custom-background, custom-colors, featured-images, theme-options
  • DATE DE CRéATION2019-05-20
  • DERNIèRE MISE à JOUR DU FICHIER2019-05-20
  • DERNIèRE VALIDATION2019-05-20 01:27
Ce thème n'est peut être pas libre. Themecheck ne distribue pas de thèmes commerciaux.
Alertes critiques
  1. Customizer : Sanitization des Customizer settings Un setting Customizer a été trouvé sans callback de sanitization dans le fichier gdlr-customizer.php. Tous les appels à la méthode add_setting() doivent déclarer une fonction de filtrage.
  2. Title : Title Absence de référence à add_theme_support( "title-tag" ) dans le thème.Le thème doit avoir des tags <title>, idéalement dans le fichier header.php.Le thème doit comporter un appel à wp_title(), idéalement dans le fichier header.php.Les tags <title> ne peuvent contenir qu'un appe à wp_title(). wp_title filter soit être utilisée pour modifier la sortie.
  3. Failles de sécurité : Utilisation de base64_decode() base64_decode trouvé dans le fichier twitteroauth.php. 208: $decoded_sig = base64_decode($signature);base64_decode trouvé dans le fichier ApiRequestor.php. 405: $derCert = base64_decode(implode('', $lines));
  4. Failles de sécurité : Utilisation de base64_encode() base64_encode trouvé dans le fichier twitteroauth.php.
     return base64_encode(hash_hmac('sha1', $base_string, $key, true));
     return base64_encode($signature);
  5. Fichiers indésirables : fichiers ou dossiers cachés .travis.yml .gitignore a été trouvé.
  6. Présence d'iframes : Les iframes sont parfois utilisées pour charger du contenu non désirés ou du code malicieux sur des sites tiers <iframe src="https://www.youtube' . ($theme_option['disable-cookie-youtube'] == 'enable'? '-nocookie': '') . '.com/embed/' . $id[1] . '?wmode=transparent' . $id[2] . '" width="' . $width . '" height="' . $height . '" > trouvé dans le fichier gdlr-media.php. 66: return '<iframe src='https://www.youtube' . ($theme_option['disable-cookie-youtube'<iframe src=|gq2|http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&amp;geocode=&amp;q=seattle&amp;aq=&amp;sll=22.447841,114.109497&amp;sspn=0.448038,0.550003&amp;vpsrc=0&amp;ie=UTF8&amp;hq=&amp;hnear=%E0%B8%8B%E0%B8%B5%E0%B9%81%E0%B8%AD%E0%B8%95%E0%B9%80%E0%B8%97%E0%B8%B4%E0%B8%A5+King,+%E0%B8%A3%E0%B8%B1%E0%B8%90%E0%B8%A7%E0%B8%AD%E0%B8%8A%E0%B8%B4%E0%B8%87%E0%B8%95%E0%B8%B1%E0%B8%99+%E0%B8%AA%E0%B8%AB%E0%B8%A3%E0%B8%B1%E0%B8%90%E0%B8%AD%E0%B9%80%E0%B8%A1%E0%B8%A3%E0%B8%B4%E0%B8%81%E0%B8%B2&amp;t=m&amp;z=12&amp;ll=47.60621,-122.332071&amp;output=embed|gq2| height=|gq2|470|gq2| width=|gq2|100%|gq2| frameborder=|gq2|0|gq2| marginwidth=|gq2|0|gq2| marginheight=|gq2|0|gq2| scrolling=|gq2|no|gq2|> trouvé dans le fichier gdlr-demo-page.php. 104: 'above-sidebar'=>'[{'item-type':'wrapper','item-builder-title':'Full Size Wrapper','type':'full-size-wrapper','items':[{'item-type':'item','item-builder-title':'Content','type':'content','option':{'page-item-id':'','title-type':'none','icon':'','title':'','caption':'','content':'<iframe src=|gq2|http://maps.google.com/maps?f=q&amp;source=s_q&amp;hl=en&a
  7. Code malveillant : Opérations sur système de fichiers file_get_contents trouvé dans le fichier gdlr-function-regist.php. 81: $default_admin_option = unserialize(file_get_contents($default_file));fopen trouvé dans le fichier gdlr-function-regist.php. 109: //$file_stream = @fopen($file_url, 'w');fwrite trouvé dans le fichier gdlr-function-regist.php. 110: //fwrite($file_stream, serialize($theme_option));fclose trouvé dans le fichier gdlr-function-regist.php. 111: //fclose($file_stream);fopen trouvé dans le fichier gdlr-admin-option.php. 21: $file_stream = @fopen($file_url, 'w');fwrite trouvé dans le fichier gdlr-admin-option.php. 52: fwrite( $file_stream, str_replace('#gdlr#', $value, $option['selector']) . 91: fwrite($file_stream, $style);96: fwrite($file_stream, $end_of_file);100: fwrite($file_stream, $theme_option['additional-style']);fwrite trouvé dans le fichier gdlr-admin-option.php. 52: fwrite( $file_stream, str_replace('#gdlr#', $value, $option['selector']) . 91: fwrite($file_stream, $style);96: fwrite($file_stream, $end_of_file);100: fwrite($file_stream, $theme_option['additional-style']);fwrite trouvé dans le fichier gdlr-admin-option.php. 52: fwrite( $file_stream, str_replace('#gdlr#', $value, $option['selector']) . 91: fwrite($file_stream, $style);96: fwrite($file_stream, $end_of_file);100: fwrite($file_stream, $theme_option['additional-style']);fwrite trouvé dans le fichier gdlr-admin-option.php. 52: fwrite( $file_stream, str_replace('#gdlr#', $value, $option['selector']) . 91: fwrite($file_stream, $style);96: fwrite($file_stream, $end_of_file);100: fwrite($file_stream, $theme_option['additional-style']);fclose trouvé dans le fichier gdlr-admin-option.php. 104: fclose($file_stream);file_get_contents trouvé dans le fichier twitteroauth.php. 278: file_get_contents(self::$POST_INPUT)file_get_contents trouvé dans le fichier paypal.php. 250: $raw_post_data = file_get_contents('php://input');file_get_contents trouvé dans le fichier goodlayers-importer.php. 37: $widget_data = unserialize(file_get_contents($widget_file));fopen trouvé dans le fichier goodlayers-importer.php. 65: //$file_stream = @fopen($widget_file, 'w');fwrite trouvé dans le fichier goodlayers-importer.php. 66: //fwrite($file_stream, serialize($widget_data));fclose trouvé dans le fichier goodlayers-importer.php. 67: //fclose($file_stream); file_get_contents trouvé dans le fichier gdlr-font-loader.php. 68: $google_fonts = json_decode(file_get_contents($google_font_file), true);
  8. Code malveillant : Opérations réseau curl_init trouvé dans le fichier twitteroauth.php. 1069: $ci = curl_init();curl_exec trouvé dans le fichier twitteroauth.php. 1095: $response = curl_exec($ci);curl_init trouvé dans le fichier paypal.php. 276: $ch = curl_init('https://ipnpb.paypal.com/cgi-bin/webscr');curl_exec trouvé dans le fichier paypal.php. 286: if( !($res = curl_exec($ch)) ) {curl_init trouvé dans le fichier ApiRequestor.php. 231: $curl = curl_init();curl_exec trouvé dans le fichier ApiRequestor.php. 264: $rbody = curl_exec($curl);281: $rbody = curl_exec($curl);curl_exec trouvé dans le fichier ApiRequestor.php. 264: $rbody = curl_exec($curl);281: $rbody = curl_exec($curl);
  9. Menu Admin : Les thèmes doivent utiliser add_theme_page () pour ajouter des pages admin. Fichier class-tgm-plugin-activation.php : 412: $this->page_hook = call_user_func( 'add_submenu_page', $args['parent_slug'], $args['page_title'], $args['menu_tFichier gdlr-admin-panel.php : 47: $page = add_menu_page($this->setting['page_title'], $this->setting['menu_title'],
  10. Inclusion de plugin : Présence de fichier zip Les plugins ne sont pas autorisés dans les thèmes. Le fichier zip gdlr-portfolio.zip goodlayers-importer.zip layerslider.zip gdlr-cause.zip gdlr-shortcode.zip a été trouvé.
Attention
  1. tags du thème : Présence de tags inconnusLe tag white est obsolète, il ne doit pas figurer dans le header de style.css.Le tag light est obsolète, il ne doit pas figurer dans le header de style.css.Le tag Green est obsolète, il ne doit pas figurer dans le header de style.css.Le tag fluid-layout est obsolète, il ne doit pas figurer dans le header de style.css.
  2. Text domain : Utilisation incorrecte des fonctions de traduction.Mauvaus répertoire d'installation pour le thème. Le nom du répertoir doit correspondre au slug du thème. Le slug de ce thème ainsi que le text-domain est charity-hub.
  3. Text domain : Utilisation incorrecte des fonctions de traduction.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'This theme requires the following plugin: %1$s.', 'This theme requires the following plugins: %1$s.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'This theme recommends the following plugin: %1$s.', 'This theme recommends the following plugins: %1$s.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'Sorry, but you do not have the correct permissions to install the %s plugin. Contact the administrator of this site for help on getting the plugin installed.', 'Sorry, but you do not have the correct permissions to install the %s plugins. Contact the administrator of this site for help on getting the plugins installed.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'The following required plugin is currently inactive: %1$s.', 'The following required plugins are currently inactive: %1$s.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'The following recommended plugin is currently inactive: %1$s.', 'The following recommended plugins are currently inactive: %1$s.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'Sorry, but you do not have the correct permissions to activate the %s plugin. Contact the administrator of this site for help on getting the plugin activated.', 'Sorry, but you do not have the correct permissions to activate the %s plugins. Contact the administrator of this site for help on getting the plugins activated.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'The following plugin needs to be updated to its latest version to ensure maximum compatibility with this theme: %1$s.', 'The following plugins need to be updated to their latest version to ensure maximum compatibility with this theme: %1$s.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'Sorry, but you do not have the correct permissions to update the %s plugin. Contact the administrator of this site for help on getting the plugin updated.', 'Sorry, but you do not have the correct permissions to update the %s plugins. Contact the administrator of this site for help on getting the plugins updated.' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'Begin installing plugin', 'Begin installing plugins' dans le fichier gdlr-plugin-activation.php.Une fonction de traduction utilisée sans text-domain. Fonction _n_noop, avec les arguments 'Activate installed plugin', 'Activate installed plugins' dans le fichier gdlr-plugin-activation.php.Plusieurs text-domain sont utilisés dans le thème. Cela signifie que le thème n'est pas compatible avec les language packs de WordPress. Les domaines trouvés sont gdlr_translate, tgmpa, gdlr, stripe.
  4. Contextes de plugin : Fonctionnalités de pluginLe thème utilise la fonction register_taxonomy(). Cette fonction n'est pas prévue pour être utilisée dans le contexte d'un thème, mais plutôt dans un plugin.Le thème utilise la fonction add_shortcode(). L'utilisation des custom post-content shortcodes est du domaine des plugins.
  5. Répertoires indésirables : Répertoire de control de version GITA.git a été trouvé.
  6. Eléments custom : Présence d'une entête customAucune référence à custom header n'a été trouvée dans le thème.
  7. Eléments custom : Présence d'un fond customAucune référence à custom background n'a été trouvée dans le thème.
  8. Image à la une ("Featured image") : Utilisation de the_post_thumbnail() instead of custom fields for thumbnailsAucune référence à the_post_thumbnail n'a été trouvée dans le thème.
  9. Screenshot : Copie d'écranLa taille du screenshot est 880x660px. La taille recommandée est 1200x900, pour prendre en compte les affichages HiDPI. Bien qu'une résolution de 1200x900 soit recommandée, toutes les images au format 4:3 sont acceptables.Mauvaise extension de fichier screenshot ! Le fichier screenshot.png n'est pas un véritable fichier JPG. Le type détecté est : "image/png".
Info
  1. Liens statiques : Présence de liens codés en durLien potentiellement codés en dur trouvé dans le fichier twitteroauth.php.1134: echo '<strong>'.$tweets->errors[0]->message.'!</strong><br />You\'ll need to regenerate it <a href='https://dev.twitter.com/apps' target='_blank'>here</a>!' . $after_widget;
  2. Fichiers optionnels : Présence du fichierde style pour les écritures de droite vers la gauche rtl.cssCe thème ne contient pas le fichier optionnel rtl.php.
  3. Fichiers optionnels : Présence du fichier-template fron-*page.phpCe thème ne contient pas le fichier optionnel front-page.php.
  4. Fichiers optionnels : Présence du fichier-template de page d'accueil home.phpCe thème ne contient pas le fichier optionnel home.php.
  5. Fichiers optionnels : Présence du fichier-template de catégorie category.phpCe thème ne contient pas le fichier optionnel category.php.
  6. Fichiers optionnels : Présence du fichier-template des tags tag.phpCe thème ne contient pas le fichier optionnel tag.php.
  7. Fichiers optionnels : Présence du fichier template de taxinomie taxonomy.phpCe thème ne contient pas le fichier optionnel taxonomy.php.
  8. Fichiers optionnels : Présence du fichier-template author.phpCe thème ne contient pas le fichier optionnel author.php.
  9. Fichiers optionnels : Présence de du fichier-template des dates et heures date.phpCe thème ne contient pas le fichier optionnel date.php.
  10. Fichiers optionnels : Présence du fichier-template des pièces jointes attachment.phpCe thème ne contient pas le fichier optionnel attachment.php.
  11. Fichiers optionnels : Présence du fichier-template des images image.phpCe thème ne contient pas le fichier optionnel image.php.
  12. Utilisation d'includes : Utilisation de include ou de de requireLe thème semble utiliser include ou require : gdlr-plugin-activation.php 2: require_once(GDLR_LOCAL_PATH . '/include/plugin/class-tgm-plugin-activation Si ces fonctions sont utilisées pour inclure des sections séparées d'un modèle à partir de fichiers indépendants, alors get_template_part () doit être utilisé à la place.Le thème semble utiliser include ou require : paypal.php 69: 72: Si ces fonctions sont utilisées pour inclure des sections séparées d'un modèle à partir de fichiers indépendants, alors get_template_part () doit être utilisé à la place.Le thème semble utiliser include ou require : Stripe.php 5: 'to require('lib/Stripe.php'); instead of this file\n';8: $ok = @include_once(dirname(__FILE__).$testURI);10: $ok = @include_once(dirname(__FILE__).'/../vendor/simpletest'.$testURI);29: require_once(dirname(__FILE__) . '/../lib/Stripe.php');31: require_once(dirname(__FILE__) . '/Stripe/TestCase.php');33: require_once(dirname(__FILE__) . '/Stripe/ApiRequestorTest.php');34: require_once(dirname(__FILE__) . '/Stripe/AuthenticationErrorTest.php');35: require_once(dirname(__FILE__) . '/Stripe/CardErrorTest.php');36: require_once(dirname(__FILE__) . '/Stripe/AccountTest.php');37: require_once(dirname(__FILE__) . '/Stripe/BalanceTest.php');38: require_once(dirname(__FILE__) . '/Stripe/BalanceTransactionTest.php');39: require_once(dirname(__FILE__) . '/Stripe/ChargeTest.php');40: require_once(dirname(__FILE__) . '/Stripe/CouponTest.php');41: require_once(dirname(__FILE__) . '/Stripe/CustomerTest.php');42: require_once(dirname(__FILE__) . '/Stripe/DiscountTest.php');43: require_once(dirname(__FILE__) . '/Stripe/Error.php');44: require_once(dirname(__FILE__) . '/Stripe/InvalidRequestErrorTest.php');45: require_once(dirname(__FILE__) . '/Stripe/InvoiceTest.php');46: require_once(dirname(__FILE__) . '/Stripe/ObjectTest.php');47: require_once(dirname(__FILE__) . '/Stripe/PlanTest.php');48: require_once(dirname(__FILE__) . '/Stripe/SubscriptionTest.php');49: require_once(dirname(__FILE__) . '/Stripe/Token.php');50: require_once(dirname(__FILE__) . '/Stripe/TransferTest.php');51: require_once(dirname(__FILE__) . '/Stripe/RecipientTest.php');52: require_once(dirname(__FILE__) . '/Stripe/RefundTest.php');53: require_once(dirname(__FILE__) . '/Stripe/ApplicationFeeTest.php');54: require_once(dirname(__FILE__) . '/Stripe/ApplicationFeeRefundTest.php');55: require_once(dirname(__FILE__) . '/Stripe/UtilTest.php'); Si ces fonctions sont utilisées pour inclure des sections séparées d'un modèle à partir de fichiers indépendants, alors get_template_part () doit être utilisé à la place.Le thème semble utiliser include ou require : Stripe.php 17: require(dirname(__FILE__) . '/Stripe/Stripe.php');20: require(dirname(__FILE__) . '/Stripe/Util.php');21: require(dirname(__FILE__) . '/Stripe/Util/Set.php');24: require(dirname(__FILE__) . '/Stripe/Error.php');25: require(dirname(__FILE__) . '/Stripe/ApiError.php');26: require(dirname(__FILE__) . '/Stripe/ApiConnectionError.php');27: require(dirname(__FILE__) . '/Stripe/AuthenticationError.php');28: require(dirname(__FILE__) . '/Stripe/CardError.php');29: require(dirname(__FILE__) . '/Stripe/InvalidRequestError.php');30: require(dirname(__FILE__) . '/Stripe/RateLimitError.php');33: require(dirname(__FILE__) . '/Stripe/Object.php');34: require(dirname(__FILE__) . '/Stripe/ApiRequestor.php');35: require(dirname(__FILE__) . '/Stripe/ApiResource.php');36: require(dirname(__FILE__) . '/Stripe/SingletonApiResource.php');37: require(dirname(__FILE__) . '/Stripe/AttachedObject.php');38: require(dirname(__FILE__) . '/Stripe/List.php');41: require(dirname(__FILE__) . '/Stripe/Account.php');42: require(dirname(__FILE__) . '/Stripe/Card.php');43: require(dirname(__FILE__) . '/Stripe/Balance.php');44: require(dirname(__FILE__) . '/Stripe/BalanceTransaction.php');45: require(dirname(__FILE__) . '/Stripe/Charge.php');46: require(dirname(__FILE__) . '/Stripe/Customer.php');47: require(dirname(__FILE__) . '/Stripe/Invoice.php');48: require(dirname(__FILE__) . '/Stripe/InvoiceItem.php');49: require(dirname(__FILE__) . '/Stripe/Plan.php');50: require(dirname(__FILE__) . '/Stripe/Subscription.php');51: require(dirname(__FILE__) . '/Stripe/Token.php');52: require(dirname(__FILE__) . '/Stripe/Coupon.php');53: require(dirname(__FILE__) . '/Stripe/Event.php');54: require(dirname(__FILE__) . '/Stripe/Transfer.php');55: require(dirname(__FILE__) . '/Stripe/Recipient.php');56: require(dirname(__FILE__) . '/Stripe/Refund.php');57: require(dirname(__FILE__) . '/Stripe/ApplicationFee.php');58: require(dirname(__FILE__) . '/Stripe/ApplicationFeeRefund.php'); Si ces fonctions sont utilisées pour inclure des sections séparées d'un modèle à partir de fichiers indépendants, alors get_template_part () doit être utilisé à la place.Le thème semble utiliser include ou require : gdlr-framework.php 10: include_once('function/gdlr-sidebar-generator.php');13: include_once('function/gdlr-admin-panel.php'); 14: include_once('function/gdlr-admin-panel-html.php'); 17: include_once('function/gdlr-customizer.php'); 20: include_once('function/gdlr-page-builder.php'); 21: include_once('function/gdlr-page-builder-html.php'); 24: include_once('function/gdlr-page-options.php'); 27: include_once('function/gdlr-tax-meta.php'); 30: include_once('function/gdlr-include-script.php'); 33: include_once('function/gdlr-font-loader.php'); Si ces fonctions sont utilisées pour inclure des sections séparées d'un modèle à partir de fichiers indépendants, alors get_template_part () doit être utilisé à la place.
Other checked themes