0
Résultats de validation

ShopKit

ShopKit

WordPress 6.5.2 theme
0
  • TYPE DE THèMEThème WordPress %s 6.5.2
  • NOM DU FICHIERshopkit.zip
  • TAILLE DU FICHIER30522512 octets
  • MD50b46a7d12ba274206349451b37b296e0
  • SHA13f4f9a176a02712ce4ea3ddf7cb9c609134a49b2
  • LICENCEPropriétaire
  • FICHIERS INCLUSCSS, PHP, XML, Bitmap images, Adobe Illustrator
  • URI DU THèME URIhttps://shopkit.xforwoocommerce.com
  • VERSION2.0.5
  • TAGSone-column, two-columns, three-columns, four-columns, left-sidebar, right-sidebar, accessibility-ready, custom-colors, custom-menu, featured-images, full-width-template, microformats, post-formats, rtl-language-support, sticky-post, theme-options, threaded
  • DATE DE CRéATION2019-09-19
  • DERNIèRE MISE à JOUR DU FICHIER2019-09-19
  • DERNIèRE VALIDATION2019-09-19 16:28
Ce thème n'est peut être pas libre. Themecheck ne distribue pas de thèmes commerciaux.
Alertes critiques
  1. Failles de sécurité : Utilisation de base64_decode() base64_decode trouvé dans le fichier ot-functions-admin.php. 5055: $decoded = base64_decode( $value ); // phpcs:ignore
  2. Failles de sécurité : Utilisation de base64_encode() base64_encode trouvé dans le fichier ot-functions-admin.php.
     return base64_encode( maybe_serialize( $value ) ); // phpcs:ignore
  3. Fichiers indésirables : fichiers ou dossiers cachés .editorconfig .travis.yml .gitignore .phpcs.ruleset.xml .jscsrc .dev-lib .jshintignore .jshintrc .eslintignore .eslintrc a été trouvé.
  4. Code malveillant : Opérations sur système de fichiers file_get_contents trouvé dans le fichier bootstrap.php. 56: $_plugin_file_src = file_get_contents( $_plugin_file_candidate );fopen trouvé dans le fichier ot-functions-admin.php. 3701: $f = @fopen( $filepath, 'w' ); // phpcs:ignore3794: $f = @fopen( $filepath, 'w' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefclose trouvé dans le fichier ot-functions-admin.php. 3756: fclose( $f ); // phpcs:ignore3838: fclose( $f ); // phpcs:ignorefopen trouvé dans le fichier ot-functions-admin.php. 3701: $f = @fopen( $filepath, 'w' ); // phpcs:ignore3794: $f = @fopen( $filepath, 'w' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefwrite trouvé dans le fichier ot-functions-admin.php. 3731: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3733: fwrite( $f, '{$markerline}' ); // phpcs:ignore3739: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3740: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3741: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3750: fwrite( $f, '/* BEGIN {$marker} */\n' ); // phpcs:ignore3751: fwrite( $f, '{$insertion}\n' ); // phpcs:ignore3752: fwrite( $f, '/* END {$marker} */\n' ); // phpcs:ignore3823: fwrite( $f, '{$markerline}\n' ); // phpcs:ignore3825: fwrite( $f, '{$markerline}' ); // phpcs:ignore3831: fwrite( $f, '' ); // phpcs:ignorefclose trouvé dans le fichier ot-functions-admin.php. 3756: fclose( $f ); // phpcs:ignore3838: fclose( $f ); // phpcs:ignore
  5. Inclusion de plugin : Présence de fichier zip Les plugins ne sont pas autorisés dans les thèmes. Le fichier zip ultimate_vc_addons.zip xforwoocommerce.zip revslider.zip js_composer.zip a été trouvé.
Attention
  1. 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 shopkit.
  2. Text domain : Utilisation incorrecte des fonctions de traduction.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 shopkit, theme-text-domain, option-tree-theme, option-tree, breadcrumb-trail.
  3. Contextes de plugin : Fonctionnalités de pluginLe thème utilise la fonction register_post_type(). Cette fonction n'est pas prévue pour être utilisée dans le contexte d'un thème, mais plutôt dans un plugin.
  4. Répertoires indésirables : Répertoire de control de version GITA.git a été trouvé.
  5. Eléments custom : Présence d'une entête customAucune référence à custom header n'a été trouvée dans le thème.
  6. Editor style : Présence de l'édition de styleAucune référence à add_editor_style() n'a été trouvée dans le thème. Il est recommandé que le thème implémente l'édition de style, de manière à faire correspondre le contenu de l'éditeur l'affichage dans le thème.
  7. Implémentation de la date et de l'heure : Utilisation de the_time()Au moins une date codée en dur a été trouvée dans le fichier class-theme.php. Il est préférable d'utiliser la fonction get_option( 'date_format' )à la place.
Info
  1. tags du thème : Présence de tags inconnusLes thèmes qui utilisent le tag accessibility-ready doivent concoder avec les règles de la revue d'accessibilité.
    Voir https://make.wordpress.org/themes/handbook/review/accessibility/
  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 résultats de recherche search.phpCe thème ne contient pas le fichier optionnel search.php.
  11. Fichiers optionnels : Présence du fichier-template des pièces jointes attachment.phpCe thème ne contient pas le fichier optionnel attachment.php.
  12. Fichiers optionnels : Présence du fichier-template des images image.phpCe thème ne contient pas le fichier optionnel image.php.
  13. Utilisation d'includes : Utilisation de include ou de de requireLe thème semble utiliser include ou require : settings-plugins.php 7: require_once ( get_template_directory() . '/framework/tgm-activation/class- 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 : Parser.php 3: require_once( get_template_directory() . '/framework/less/lib/Less/Cache.ph515: return include($cache_file); 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 : Cache.php 3: require_once( get_template_directory() . '/framework/less/lib/Less/Version.140: require_once($file); 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 : settings-theme.php 44: require_once( get_template_directory() . '/framework/less/lessc.inc.php' );947: include( 'fonts.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 : settings-ot.php 4214: include( 'fonts.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 : demo-functions.php 65: # require( trailingslashit( get_template_directory() ) . 'option-tree/ot-load70: # require( trailingslashit( get_template_directory() ) . 'admin/theme-options 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 : ot-functions-docs-page.php 874: require( trailingslashit( get_template_directory() ) . \'includes/meta-boxe970: require( trailingslashit( get_template_directory() ) . \'option-tree/ot-loa999: require( trailingslashit( get_template_directory() ) . \'includes/theme-opt 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