[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"$fqnJde_lx_01YSVBITD-ifGtV4zB60V3b2qG54ZaCFhk":3},{"slug":4,"name":5,"version":6,"author":7,"author_profile":8,"description":9,"short_description":10,"active_installs":11,"downloaded":12,"rating":11,"num_ratings":11,"last_updated":13,"tested_up_to":14,"requires_at_least":15,"requires_php":16,"tags":17,"homepage":23,"download_link":24,"security_score":25,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27,"vulnerabilities":28,"developer":29,"crawl_stats":26,"alternatives":34,"analysis":133,"fingerprints":202},"ethne-favourites","Ethne Favorites Button","1.0.8","djrobertson","https:\u002F\u002Fprofiles.wordpress.org\u002Fdjrobertson\u002F","\u003Cp>The Ethne Favorites Button plugin for WordPress provides a shortcode that will allow users to save their favorite posts and pages, it also includes an option to display and remove favorite posts and pages for the user. Compatible with Cooked plugin favourites (access cooked favourites without cooked plugin)\u003C\u002Fp>\n\u003Ch3>Shortcode Usage\u003C\u002Fh3>\n\u003Ch4>How to display the list\u003C\u002Fh4>\n\u003Cp>Use the following shortcode:\u003Cbr \u002F>\n[ethne-favorites]\u003C\u002Fp>\n\u003Ch4>How to display the button\u003C\u002Fh4>\n\u003Cp>Use the following shortcode:\u003Cbr \u002F>\n[ethne-favorites view=”Button”]\u003C\u002Fp>\n","Favorite buttons for WordPress, Shortcodes to save and list favorite posts and pages for each user.",0,832,"2022-10-26T04:03:00.000Z","6.0.11","","5.2",[18,19,20,21,22],"cooked-plugin","favorite","favourite","like-post","save-post","https:\u002F\u002Fderek.net.au","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fethne-favourites.1.0.8.zip",85,null,"2026-03-15T15:16:48.613Z",[],{"slug":7,"display_name":7,"profile_url":8,"plugin_count":30,"total_installs":11,"avg_security_score":25,"avg_patch_time_days":31,"trust_score":32,"computed_at":33},1,30,84,"2026-04-05T20:43:50.099Z",[35,53,73,92,115],{"slug":36,"name":37,"version":38,"author":39,"author_profile":40,"description":41,"short_description":42,"active_installs":43,"downloaded":44,"rating":45,"num_ratings":30,"last_updated":46,"tested_up_to":15,"requires_at_least":15,"requires_php":15,"tags":47,"homepage":51,"download_link":52,"security_score":25,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"wp-favorite-posts-extended","WP Favorite Posts Extended","1.6.2","avrilmaomao","https:\u002F\u002Fprofiles.wordpress.org\u002Favrilmaomao\u002F","\u003Cp>This plugin is based on “WP Favorite Posts”,and extends json api to provide access for mobile apps.\u003Cbr \u002F>\nThree methods are provided:\u003Cbr \u002F>\nwpfp\u002Fadd\u003Cbr \u002F>\n     postid: required\u003Cbr \u002F>\n     cookie: optional\u003Cbr \u002F>\nwpfp\u002Fremove\u003Cbr \u002F>\n    postid：required\u003Cbr \u002F>\n    cookie：optional\u003Cbr \u002F>\nwpfp\u002Flists\u003Cbr \u002F>\n    cookie ：optional\u003Cbr \u002F>\nThe cookie param is the same as “JSON API USER” plugin used.\u003C\u002Fp>\n\u003Cp>These methods support users not logged,if the client side can receive and send cookies.\u003C\u002Fp>\n\u003Cp>code can be found at: https:\u002F\u002Fgithub.com\u002Favrilmaomao\u002Fwp-favorite-posts-extended\u003C\u002Fp>\n","wp-favorite-posts, reading list, post list, post lists, lists Requires at least: 3.5 Tested up to: 4.0 Stable tag: 0.1 Based on plugin \"WP Favor &hellip;",20,3836,80,"2014-11-06T07:16:00.000Z",[19,48,49,20,50],"favorite-posts","favorites","posts","https:\u002F\u002Fgithub.com\u002Favrilmaomao\u002Fwp-favorite-posts-extended","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fwp-favorite-posts-extended.zip",{"slug":54,"name":55,"version":56,"author":57,"author_profile":58,"description":59,"short_description":60,"active_installs":11,"downloaded":61,"rating":11,"num_ratings":11,"last_updated":15,"tested_up_to":62,"requires_at_least":63,"requires_php":64,"tags":65,"homepage":15,"download_link":70,"security_score":71,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":72},"jiali-user-bookmarks","Jiali User Bookmarks","1.0.1","Mahyar","https:\u002F\u002Fprofiles.wordpress.org\u002Fmrgrad\u002F","\u003Cp>Jiali User Bookmarks is a lightweight and developer-friendly WordPress plugin that allows users to save posts for later reading.\u003Cbr \u002F>\nYou can choose the wording that best fits your site — “Bookmark”, “Save”, or “Favorite”.\u003Cbr \u002F>\nIt’s fully AJAX-powered for a seamless user experience — no page reloads required.\u003C\u002Fp>\n\u003Cp>Perfect for blogs, news sites, tutorials, or any content-rich site where readers may want to come back to specific articles later.\u003C\u002Fp>\n\u003Ch3>🚀 Features\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>📑 One-click Bookmark \u002F Save \u002F Favorite button for posts  \u003C\u002Fli>\n\u003Cli>🎨 Custom styles — easily override the button styles with your own CSS  \u003C\u002Fli>\n\u003Cli>📋 Display bookmarks using flexible shortcodes  \u003C\u002Fli>\n\u003Cli>⚡ AJAX-powered (no page reloads)  \u003C\u002Fli>\n\u003Cli>🔐 Works only for logged-in users (for personalization & security)  \u003C\u002Fli>\n\u003Cli>📊 Display bookmark counts and lists dynamically  \u003C\u002Fli>\n\u003Cli>🧩 Shortcode support for easy placement in page builders, templates, or loops  \u003C\u002Fli>\n\u003Cli>🧼 Lightweight, extendable, and developer-friendly (uses WordPress standards)  \u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>🛠️ Developer Notes\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Coded with WordPress best practices (escaping, nonce validation, cache support)  \u003C\u002Fli>\n\u003Cli>Compatible with block themes and classic themes\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Credits\u003C\u002Fh3>\n\u003Cp>Developed by \u003Ca href=\"https:\u002F\u002Fmahyarerad.com\" rel=\"nofollow ugc\">Mahyar Rad\u003C\u002Fa>\u003C\u002Fp>\n\u003Ch3>License\u003C\u002Fh3>\n\u003Cp>This plugin is licensed under GPLv2 or later.\u003C\u002Fp>\n","Let your visitors easily bookmark, save, or favorite posts! Lightweight, AJAX-powered plugin to boost user engagement and interactivity. 📑✨",192,"6.8.5","5.0","7.2",[66,67,49,68,69],"ajax","bookmarks","reading-list","save-posts","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fjiali-user-bookmarks.1.0.1.zip",100,"2026-03-15T10:48:56.248Z",{"slug":74,"name":75,"version":76,"author":77,"author_profile":78,"description":79,"short_description":80,"active_installs":11,"downloaded":81,"rating":11,"num_ratings":11,"last_updated":82,"tested_up_to":62,"requires_at_least":83,"requires_php":84,"tags":85,"homepage":15,"download_link":91,"security_score":71,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"techvoot-favourites-for-woocommerce","Techvoot Favourites for WooCommerce","1.0.0","Techvoot Solutions","https:\u002F\u002Fprofiles.wordpress.org\u002Ftechvootsolutions\u002F","\u003Cp>\u003Cstrong>Customer Favourites for WooCommerce\u003C\u002Fstrong> helps customers quickly reorder their most frequently purchased items by allowing them to save products as Favourites.\u003C\u002Fp>\n\u003Cp>This plugin adds a \u003Cstrong>“Save to Favourites”\u003C\u002Fstrong> button to each product page and a \u003Cstrong>“My Favourites”\u003C\u002Fstrong> page where users can view and manage their saved products.\u003C\u002Fp>\n\u003Cp>Upon activation, the plugin \u003Cstrong>automatically creates a “My Favourites” page\u003C\u002Fstrong> with the \u003Ccode>[tvwf_user_favourites]\u003C\u002Fcode> shortcode, which displays the current logged-in user’s Favourite products.\u003Cbr \u002F>\nAlternatively, administrators can \u003Cstrong>manually insert the shortcode on any page\u003C\u002Fstrong> to show the user’s favourites list wherever it fits the site’s layout best.\u003C\u002Fp>\n\u003Ch3>🛍️ Frontend Features:\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Logged-in users can save\u002Fremove products as Favourites.\u003C\u002Fli>\n\u003Cli>Adds a “Save to Favourites” button on each WooCommerce product page.\u003C\u002Fli>\n\u003Cli>Favourite products persist even after placing an order.\u003C\u002Fli>\n\u003Cli>Automatically creates a “My Favourites” page showing saved products using a shortcode.\u003C\u002Fli>\n\u003Cli>“My Favourites” page displays saved products.\u003C\u002Fli>\n\u003Cli>Admins can insert the \u003Ccode>[tvwf_user_favourites]\u003C\u002Fcode> shortcode on any other page if desired.\u003C\u002Fli>\n\u003Cli>Favourite products persist even after placing an order.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>⚙️ Backend Features:\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>New admin section to manage Favourites per user.\u003C\u002Fli>\n\u003Cli>View a list of each user’s Favourite products.\u003C\u002Fli>\n\u003Cli>Admins can manually add or remove products from a user’s Favourites list.\u003C\u002Fli>\n\u003Cli>Accessible directly from the WordPress Users list screen via a new “Favourites” button beside each user.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>📦 Use Cases:\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Perfect for B2B shops or customers who frequently reorder the same items.\u003C\u002Fli>\n\u003Cli>Simplifies the ordering experience for returning customers.\u003C\u002Fli>\n\u003C\u002Ful>\n","Lets WooCommerce customers save products as Favourites for quick reordering, with admin tools to manage each user's saved products.",247,"2025-05-13T14:30:00.000Z","6.5","7.4",[86,87,88,89,90],"customer-favorites","favourites","products","reorder","woocommerce","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Ftechvoot-favourites-for-woocommerce.1.0.0.zip",{"slug":49,"name":93,"version":94,"author":95,"author_profile":96,"description":97,"short_description":98,"active_installs":99,"downloaded":100,"rating":101,"num_ratings":102,"last_updated":103,"tested_up_to":62,"requires_at_least":104,"requires_php":105,"tags":106,"homepage":110,"download_link":111,"security_score":112,"vuln_count":113,"unpatched_count":30,"last_vuln_date":114,"fetched_at":27},"Favorites","2.3.6","Kyle Phillips","https:\u002F\u002Fprofiles.wordpress.org\u002Fkylephillips\u002F","\u003Cp>\u003Cstrong>Why Favorites?\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>Favorites is designed for end users and theme developers. It provides an easy-to-use API for adding favorite button functionality to any post type.\u003C\u002Fp>\n\u003Cp>The plugin can provide a way to save favorites, likes, bookmarks, or any other similar types of data with its customizable button text.\u003C\u002Fp>\n\u003Cp>Visit \u003Ca href=\"http:\u002F\u002Ffavoriteposts.com\" rel=\"nofollow ugc\">favoriteposts.com\u003C\u002Fa> for a full list of available template functions and shortcodes.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Features\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Use with Any Post Type\u003C\u002Fstrong> – Enable or disable favorite functionality per post type while automatically adding a favorite button before and\u002For after the content. Or, use the included functions to display the button anywhere in your template.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Available for All Users\u003C\u002Fstrong> – Don’t want to hide functionality behind a login? Favorites includes an option to save anonymous users’ favorites by either Session or Cookie. Logged-In users’ favorites are also saved as user meta\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Designed for Developers\u003C\u002Fstrong> – Favorites works great out-of-the-box for beginners, but a full set of template functions unlocks just about any sort of custom functionality developers may need. Favorites outputs the minimum amount of markup needed, putting the style and control in your hands.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>GDPR\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>As of version 2.2, a setting is provided to help comply with GDPR standards. To enable this setting, visit Settings > Favorites > Users, and check the field under “User Cookie Consent.” When this setting is enabled, the content saved under the setting displays in a modal window, and the user must agree to the terms you provide before favorite cookies can be saved. Note: There is no language provided by default. This should be supplied by a qualified attorney or legal entity. Once the user has approved or denied cookies, that is saved in the “simplefavorites” cookie along with the timestamp of approval or denial. If the site is part of a multi-site installation, the setting will carry through to all sites.\u003C\u002Fp>\n\u003Cp>If your site already has a cookie compliance solution in place, there are two document-level jQuery events that may be triggered in order to approve or deny cookies in the background.\u003C\u002Fp>\n\u003Cp>To approve the use of cookies, trigger the event “favorites-user-consent-approved”. To deny the use of cookies, trigger the event “favorites-user-consent-denied”.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Multisite Compatible\u003C\u002Fstrong> – As of version 1.1.0, Favorites is multisite compatible. User favorites are saved on a site\u002Fblog basis, and may be retrieved and displayed across sites.\u003C\u002Fp>\n\u003Cp>For more information visit \u003Ca href=\"http:\u002F\u002Ffavoriteposts.com\" rel=\"nofollow ugc\">favoriteposts.com\u003C\u002Fa>.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Important: Favorites requires WordPress version 3.8 or higher, and PHP version 5.4 or higher.\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Ch3>Usage\u003C\u002Fh3>\n\u003Cp>\u003Cstrong>Favorite Button\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>The favorite button can be added automatically to the content by enabling specific post types in the plugin settings. It may also be added to template files or through the content editor using the included functions or shortcodes. The post id may be left blank in all cases if inside the loop. The site id parameter is optional, for use in multisite installations (defaults to current site).\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function:\u003C\u002Fstrong> \u003Ccode>get_favorites_button($post_id, $site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function:\u003C\u002Fstrong> \u003Ccode>the_favorites_button($post_id, $site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode:\u003C\u002Fstrong> \u003Ccode>[favorite_button post_id=\"\" site_id=\"\"]\u003C\u002Fcode>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>Favorite Count (by Post)\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>Total favorites for each post are saved as a simple integer. If a user unfavorites a post, this count is updated. Anonymous users’ favorites count towards the total by default, but may be disabled via the plugin settings. The post id may be left blank in all cases if inside the loop.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function:\u003C\u002Fstrong> \u003Ccode>get_favorites_count($post_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function:\u003C\u002Fstrong> \u003Ccode>the_favorites_count($post_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode:\u003C\u002Fstrong> \u003Ccode>[favorite_count post_id=\"\"]\u003C\u002Fcode>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>Favorite Count (by User)\u003C\u002Fstrong>\u003Cbr \u002F>\nDisplays the total number of favorites a user has favorited. Template functions accept the same filters parameter as the user favorites functions.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function:\u003C\u002Fstrong> \u003Ccode>get_user_favorites_count($user_id, $site_id, $filters)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function:\u003C\u002Fstrong> \u003Ccode>the_user_favorites_count($user_id, $site_id, $filters)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode:\u003C\u002Fstrong> \u003Ccode>[user_favorites user_id=\"\" site_id=\"\" post_types=\"\"]\u003C\u002Fcode>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>User Favorites\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>User favorites are stored as an array of post ids. Logged-in users’ favorites are stored as a custom user meta field, while anonymous users’ favorites are stored in either the session or browser cookie (configurable in the plugin settings). If the user id parameter is omitted, the favorites default to the current user. The site id parameter is optional, for use in multisite installations (defaults to current site).\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function (returns array of IDs):\u003C\u002Fstrong> \u003Ccode>get_user_favorites($user_id, $site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Get function (returns html list):\u003C\u002Fstrong> \u003Ccode>get_user_favorites_list($user_id, $site_id, $include_links, $filters, $include_button, $include_thumbnails = false, $thumbnail_size = 'thumbnail', $include_excerpt = false)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function (prints an html list):\u003C\u002Fstrong> \u003Ccode>the_user_favorites_list($user_id, $site_id, $include_links, $filters, $include_button, $include_thumbnails = false, $thumbnail_size = 'thumbnail', $include_excerpt = false)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode (prints an html list, with the option of omitting links):\u003C\u002Fstrong> `[user_favorites user_id=”” include_links=”true” site_id=”” include_buttons=”false” post_types=”post” include_thumbnails=”false” thumbnail_size=”thumbnail” include_excerpt=”false”]\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>List Users Who Have Favorited a Post\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>Display a list of users who have favorited a specific post. If the user id parameter is omitted, the favorites default to the current user. The site id parameter is optional, for use in multisite installations (defaults to current site). The get function returns an array of user objects.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function (returns array of User Objects):\u003C\u002Fstrong> \u003Ccode>get_users_who_favorited_post($post_id, $site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function (prints an html list):\u003C\u002Fstrong> \u003Ccode>the_users_who_favorited_post($post_id = null, $site_id = null, $separator = 'list', $include_anonymous = true, $anonymous_label = 'Anonymous Users', $anonymous_label_single = 'Anonymous User')\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode (prints an html list):\u003C\u002Fstrong> `[post_favorites post_id=”” site_id=”” separator=”list” include_anonymous=”true” anonymous_label=”Anonymous Users” anonymous_label_single=”Anonymous User”]\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>Clear Favorites Button\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>Displays a button that allows users to clear all of their favorites.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function:\u003C\u002Fstrong> \u003Ccode>get_clear_favorites_button($site_id, $text)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function:\u003C\u002Fstrong> \u003Ccode>the_clear_favorites_button($site_id, $text)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Shortcode:\u003C\u002Fstrong> `[clear_favorites_button site_id=”” text=”Clear Favorites”]\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>Favorite Count (Across all Posts)\u003C\u002Fstrong>\u003Cbr \u002F>\nDisplays the total number of favorites for a given site.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Get function:\u003C\u002Fstrong> \u003Ccode>get_total_favorites_count($site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Print function:\u003C\u002Fstrong> \u003Ccode>the_total_favorites_count($site_id)\u003C\u002Fcode>\u003C\u002Fli>\n\u003C\u002Ful>\n","Favorites for any post type. Easily add favoriting\u002Fliking, wishlists, or any other similar functionality using the developer-friendly API.",10000,293250,92,132,"2025-04-10T17:30:00.000Z","3.8","5.4",[107,19,49,108,109],"bookmark","like","likes","http:\u002F\u002Ffavoriteposts.com","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Ffavorites.2.3.6.zip",71,4,"2025-07-21 00:00:00",{"slug":116,"name":117,"version":118,"author":119,"author_profile":120,"description":121,"short_description":122,"active_installs":123,"downloaded":124,"rating":71,"num_ratings":113,"last_updated":125,"tested_up_to":126,"requires_at_least":63,"requires_php":84,"tags":127,"homepage":15,"download_link":132,"security_score":71,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"hivepress-favorites","HivePress Favorites","1.2.2","HivePress","https:\u002F\u002Fprofiles.wordpress.org\u002Fhivepress\u002F","\u003Cp>HivePress Favorites is an extension for \u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fplugins\u002Fhivepress\u002F\" rel=\"ugc\">HivePress\u003C\u002Fa> plugin. It allows users to keep a list of favorite listings.\u003C\u002Fp>\n\u003Cp>\u003Ca href=\"https:\u002F\u002Flistinghive.hivepress.io\u002F\" rel=\"nofollow ugc\">Demo\u003C\u002Fa> | \u003Ca href=\"https:\u002F\u002Fhelp.hivepress.io\u002F\" rel=\"nofollow ugc\">Docs\u003C\u002Fa> | \u003Ca href=\"https:\u002F\u002Fcommunity.hivepress.io\u002F\" rel=\"nofollow ugc\">Support\u003C\u002Fa>\u003C\u002Fp>\n","Allow users to keep a list of favorite listings.",8000,76738,"2026-02-12T23:10:00.000Z","6.9.4",[128,129,49,130,131],"classifieds","directory","hivepress","listings","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fhivepress-favorites.1.2.2.zip",{"attackSurface":134,"codeSignals":162,"taintFlows":185,"riskAssessment":186,"analyzedAt":201},{"hooks":135,"ajaxHandlers":141,"restRoutes":154,"shortcodes":155,"cronEvents":160,"entryPointCount":161,"unprotectedCount":113},[136],{"type":137,"name":138,"callback":138,"file":139,"line":140},"action","init","ethne-favourites.php",31,[142,147,149,152],{"action":143,"nopriv":144,"callback":143,"hasNonce":145,"hasCapCheck":145,"file":139,"line":146},"add_favorite",true,false,33,{"action":143,"nopriv":145,"callback":143,"hasNonce":145,"hasCapCheck":145,"file":139,"line":148},34,{"action":150,"nopriv":144,"callback":150,"hasNonce":145,"hasCapCheck":145,"file":139,"line":151},"remove_favorite",36,{"action":150,"nopriv":145,"callback":150,"hasNonce":145,"hasCapCheck":145,"file":139,"line":153},37,[],[156],{"tag":157,"callback":158,"file":139,"line":159},"ethne-favorites","ethne_shortcode",50,[],5,{"dangerousFunctions":163,"sqlUsage":164,"outputEscaping":169,"fileOperations":11,"externalRequests":11,"nonceChecks":11,"capabilityChecks":11,"bundledLibraries":184},[],{"prepared":11,"raw":30,"locations":165},[166],{"file":139,"line":167,"context":168},114,"$wpdb->get_col() with variable interpolation",{"escaped":11,"rawEcho":161,"locations":170},[171,175,177,180,182],{"file":172,"line":173,"context":174},"page-templates\\favorites-button.php",6,"raw output",{"file":172,"line":176,"context":174},10,{"file":178,"line":179,"context":174},"page-templates\\favorites-display.php",8,{"file":178,"line":181,"context":174},21,{"file":178,"line":183,"context":174},29,[],[],{"summary":187,"deductions":188},"The 'ethne-favourites' plugin v1.0.8 exhibits a poor security posture due to a significant number of unprotected entry points. The static analysis reveals 5 total entry points, with a concerning 4 of them lacking authentication checks. This indicates a high likelihood of unauthorized access and potential manipulation of plugin functionalities. Furthermore, the complete absence of output escaping and the use of raw SQL queries without prepared statements are critical security flaws that can lead to cross-site scripting (XSS) and SQL injection vulnerabilities, respectively. The lack of nonce checks on AJAX handlers exacerbates the risk of CSRF attacks. Despite no recorded vulnerability history or critical taint flows, the observed coding practices present substantial inherent risks that could be exploited by attackers. While the plugin has no known vulnerabilities and a clean history, this is likely due to its current lack of rigorous security testing or the absence of widespread adoption, rather than robust security measures. Therefore, immediate remediation of the identified security weaknesses is strongly advised.",[189,191,193,195,197,199],{"reason":190,"points":176},"4 AJAX handlers without auth checks",{"reason":192,"points":161},"1 shortcode without auth checks",{"reason":194,"points":176},"1 SQL query without prepared statements",{"reason":196,"points":179},"5 outputs not properly escaped",{"reason":198,"points":176},"0 Nonce checks",{"reason":200,"points":176},"0 Capability checks","2026-03-17T06:11:50.387Z",{"wat":203,"direct":212},{"assetPaths":204,"generatorPatterns":207,"scriptPaths":208,"versionParams":209},[205,206],"\u002Fwp-content\u002Fplugins\u002Fethne-favourites\u002Fethne-base.css","\u002Fwp-content\u002Fplugins\u002Fethne-favourites\u002Fethne.js",[],[206],[210,211],"ethne-favourites\u002Fethne-base.css?ver=","ethne-favourites\u002Fethne.js?ver=",{"cssClasses":213,"htmlComments":217,"htmlAttributes":218,"restEndpoints":220,"jsGlobals":221,"shortcodeOutput":223},[214,215,216],"favorites-button","favorites-remove-button","favorite-display",[],[219],"data-id",[],[222],"ethne",[224,225,226,227],"\u003Cbutton class=\"favorites-button\"","\u003Cbutton class='favorites-remove-button'","\u003Cdiv class=\"favorite-display\">","\u003Ca href='"]