[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"$fMxvosXNI59EZC8JrDvH_87sQ01SgHOhY7i55rh18qJA":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":35,"analysis":131,"fingerprints":191},"cpt-recent-entries-widgets","Custom Post Type Recent Entries Widget","1.0.0","Mahdi Namaki","https:\u002F\u002Fprofiles.wordpress.org\u002Fmavenium\u002F","\u003Cp>Display a list of the most recent “Custom Post Type” entries in the WordPress widgets.\u003C\u002Fp>\n","Display a list of the most recent \"Custom Post Type\" entries in the WordPress widgets.",0,3039,"2020-06-17T15:02:00.000Z","5.4.19","4.9","5.2.4",[18,19,20,21,22],"custom","custom-post-type","custom-post-types","widget","widgets","https:\u002F\u002Fgithub.com\u002Fmavenium\u002FCPT.Recent.Entries","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fcpt-recent-entries-widgets.1.0.zip",85,null,"2026-03-15T15:16:48.613Z",[],{"slug":30,"display_name":7,"profile_url":8,"plugin_count":31,"total_installs":11,"avg_security_score":25,"avg_patch_time_days":32,"trust_score":33,"computed_at":34},"mavenium",1,30,84,"2026-04-05T09:49:15.218Z",[36,60,79,97,111],{"slug":37,"name":38,"version":39,"author":40,"author_profile":41,"description":42,"short_description":43,"active_installs":44,"downloaded":45,"rating":46,"num_ratings":31,"last_updated":47,"tested_up_to":48,"requires_at_least":49,"requires_php":50,"tags":51,"homepage":55,"download_link":56,"security_score":57,"vuln_count":58,"unpatched_count":11,"last_vuln_date":59,"fetched_at":27},"apollo13-framework-extensions","Apollo13 Framework Extensions","1.9.9","apollo13themes","https:\u002F\u002Fprofiles.wordpress.org\u002Fapollo13themes\u002F","\u003Cp>\u003Cstrong>Apollo13 Framework Extensions\u003C\u002Fstrong> adds few features to themes build on Apollo13 Framework. These are:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Designs Importer,\u003C\u002Fli>\n\u003Cli>shortcodes based on Apollo13 Framework features: writtng effect, count down, socials, scroller, slider, galleries, post grid,\u003C\u002Fli>\n\u003Cli>support for WPBakery Page Builder elements added by Apollo13 Framework,\u003C\u002Fli>\n\u003Cli>custom post types: albums, works & people,\u003C\u002Fli>\n\u003Cli>Export\u002FImport of theme options,\u003C\u002Fli>\n\u003Cli>Custom Sidebar,\u003C\u002Fli>\n\u003Cli>Custom CSS,\u003C\u002Fli>\n\u003Cli>Meta options that are creating content for posts, pages, albums and works,\u003C\u002Fli>\n\u003Cli>Responsive Image resizing ,\u003C\u002Fli>\n\u003Cli>Maintenance mode.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>This plugin requires one of themes build on \u003Cstrong>Apollo13 Framework\u003C\u002Fstrong> theme to be installed.\u003C\u002Fp>\n\u003Cp>It is mostly used for:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fapollo13themes.com\u002Frife\u002Ffree\u002F\" rel=\"nofollow ugc\">Rife Free\u003C\u002Fa>\u003C\u002Fli>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fapollo13themes.com\u002Frife\u002F\" rel=\"nofollow ugc\">Rife Pro\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Credits & Copyright\u003C\u002Fh3>\n\u003Ch4>Anime.js, Copyright 2019 Julian Garnier\u003C\u002Fh4>\n\u003Cp>Licenses: MIT\u003Cbr \u002F>\nSource: https:\u002F\u002Fanimejs.com\u002F\u003C\u002Fp>\n","Adds custom post types, shortcodes and some features that are used in themes built on Apollo13 Framework.",20000,534616,100,"2025-12-04T08:12:00.000Z","6.5.8","4.7","5.4.0",[20,52,53,54],"elementor-widgets","shortcodes","wpbakery-page-builder-support","https:\u002F\u002Fapollo13themes.com\u002Frife\u002Ffree","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fapollo13-framework-extensions.zip",95,6,"2026-02-18 15:32:44",{"slug":61,"name":62,"version":63,"author":64,"author_profile":65,"description":66,"short_description":67,"active_installs":11,"downloaded":68,"rating":11,"num_ratings":11,"last_updated":69,"tested_up_to":70,"requires_at_least":71,"requires_php":72,"tags":73,"homepage":77,"download_link":78,"security_score":25,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"labtheme-companion","LabTheme Companion","1.0.2","labtheme","https:\u002F\u002Fprofiles.wordpress.org\u002Flabtheme\u002F","\u003Cp>Labtheme Companion is a lightweight and safe premium plugin. The plugin generates seven custom post types (FAQs, Clients, Events, Services, Portfolios, Team, Courses and Testimonials), exclusive widgets, and some useful shortcodes.\u003C\u002Fp>\n","The plugin generates multiple custom post types and number of exclusive widgets which are needed for wordpress theme developed by labtheme",1222,"2019-05-06T12:39:00.000Z","5.1.22","4.3","",[74,20,75,76],"comments","custom-widgets","spam","https:\u002F\u002Fwordpress.org\u002Fplugins\u002Flabtheme-companion","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Flabtheme-companion.1.0.2.zip",{"slug":80,"name":81,"version":82,"author":83,"author_profile":84,"description":85,"short_description":86,"active_installs":11,"downloaded":87,"rating":11,"num_ratings":11,"last_updated":88,"tested_up_to":89,"requires_at_least":90,"requires_php":91,"tags":92,"homepage":95,"download_link":96,"security_score":46,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"matcha-extra","Matcha Extra","1.0.3","wpmatcha","https:\u002F\u002Fprofiles.wordpress.org\u002Fwpmatcha\u002F","\u003Cp>Used for adding extra features to WP Matcha Themes.\u003C\u002Fp>\n\u003Ch3>Support\u003C\u002Fh3>\n\u003Cp>For support and documentation, please visit our website or contact our support team.\u003C\u002Fp>\n\u003Ch3>Credits\u003C\u002Fh3>\n\u003Cp>Developed by WP Matcha to enhance WordPress themes with additional functionality.\u003C\u002Fp>\n\u003Ch3>License\u003C\u002Fh3>\n\u003Cp>This plugin is licensed under the GPL v2 or later.\u003C\u002Fp>\n\u003Cblockquote>\n\u003Cp>This program is free software; you can redistribute it and\u002For modify\u003Cbr \u002F>\n  it under the terms of the GNU General Public License, version 2, as\u003Cbr \u002F>\n  published by the Free Software Foundation.\u003C\u002Fp>\n\u003Cp>This program is distributed in the hope that it will be useful,\u003Cbr \u002F>\n  but WITHOUT ANY WARRANTY; without even the implied warranty of\u003Cbr \u002F>\n  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\u003Cbr \u002F>\n  GNU General Public License for more details.\u003C\u002Fp>\n\u003Cp>You should have received a copy of the GNU General Public License\u003Cbr \u002F>\n  along with this program; if not, write to the Free Software\u003Cbr \u002F>\n  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA\u003C\u002Fp>\n\u003C\u002Fblockquote>\n","Used for adding extra features to WP Matcha Themes.",205,"2026-01-09T15:08:00.000Z","6.9.4","5.0","7.4",[93,20,53,94,22],"companion","theme","https:\u002F\u002Fwpmatcha.com\u002Fmatcha-extra","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fmatcha-extra.1.0.3.zip",{"slug":98,"name":99,"version":100,"author":99,"author_profile":101,"description":102,"short_description":103,"active_installs":11,"downloaded":104,"rating":11,"num_ratings":11,"last_updated":72,"tested_up_to":105,"requires_at_least":90,"requires_php":91,"tags":106,"homepage":72,"download_link":109,"security_score":46,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":110},"optipub","OptiPub","1.0.14","https:\u002F\u002Fprofiles.wordpress.org\u002Foptipub\u002F","\u003Cp>OptiPub synchronizes content from the OptiPub platform to your WordPress installation. Creates custom post types for Resources, Videos, FAQs and Authors with automated sync every 5 minutes via WP-Cron.\u003C\u002Fp>\n\u003Cp>Features: Custom post types (Resources, Videos, FAQs, Authors), automated content synchronization via WP-Cron, secure API authentication with encrypted token storage, multiple publication support, widget integration with custom content, tag and category management, static and dynamic pages sync, redirect handling, theme template integration, and file copying utilities.\u003C\u002Fp>\n\u003Ch3>Source Code for Minified Files\u003C\u002Fh3>\n\u003Cp>This plugin includes one minified JavaScript file (\u003Ccode>public\u002Fjs\u002Fvideo.js\u003C\u002Fcode>) which is a third-party library. The source code for this minified file is publicly available:\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Video.js v4.6.3\u003C\u002Fstrong> (Location: \u003Ccode>public\u002Fjs\u002Fvideo.js\u003C\u002Fcode>)\u003Cbr \u002F>\n* \u003Cstrong>Source Code Repository:\u003C\u002Fstrong> https:\u002F\u002Fgithub.com\u002Fvideojs\u002Fvideo.js\u002Ftree\u002Fv4.6.3\u003Cbr \u002F>\n* \u003Cstrong>License:\u003C\u002Fstrong> Apache 2.0\u003Cbr \u002F>\n* \u003Cstrong>Documentation:\u003C\u002Fstrong> https:\u002F\u002Fdocs.videojs.com\u002F\u003C\u002Fp>\n\u003Cp>All other JavaScript and CSS files in this plugin (\u003Ccode>public\u002Fjs\u002Farchive-filters.js\u003C\u002Fcode>, \u003Ccode>public\u002Fjs\u002Fgtm.js\u003C\u002Fcode>, \u003Ccode>public\u002Fjs\u002Finit.js\u003C\u002Fcode>, \u003Ccode>public\u002Fjs\u002Flogin-forms.js\u003C\u002Fcode>, \u003Ccode>public\u002Fjs\u002Fnavigation-collapse.js\u003C\u002Fcode>, and \u003Ccode>public\u002Fcss\u002Fsubscribers.css\u003C\u002Fcode>) are provided in their original, unminified source code format and are fully human-readable.\u003C\u002Fp>\n\u003Ch3>External services\u003C\u002Fh3>\n\u003Cp>This plugin connects to the following external services:\u003C\u002Fp>\n\u003Ch4>Google Tag Manager\u003C\u002Fh4>\n\u003Cp>Provides tag management and analytics functionality when GTM containers are configured in OptiPub. Sends the container ID to www.googletagmanager.com on every page load. Data collection is controlled by your GTM configuration.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Service Provider: Google LLC  \u003C\u002Fli>\n\u003Cli>Terms of Use: https:\u002F\u002Fwww.google.com\u002Fanalytics\u002Ftag-manager\u002Fuse-policy\u002F  \u003C\u002Fli>\n\u003Cli>Privacy Policy: https:\u002F\u002Fpolicies.google.com\u002Fprivacy\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>YouTube\u003C\u002Fh4>\n\u003Cp>Embeds YouTube videos when video content is configured to use YouTube as the player. Sends video IDs to youtube.com\u002Fembed only when displaying YouTube video content. Data collection is controlled by YouTube’s privacy policy.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Service Provider: Google LLC (YouTube)  \u003C\u002Fli>\n\u003Cli>Terms of Use: https:\u002F\u002Fwww.youtube.com\u002Fstatic?template=terms  \u003C\u002Fli>\n\u003Cli>Privacy Policy: https:\u002F\u002Fpolicies.google.com\u002Fprivacy\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Wistia\u003C\u002Fh4>\n\u003Cp>Embeds Wistia videos when video content is configured to use Wistia as the player. Sends video IDs to fast.wistia.net only when displaying Wistia video content. Data collection is controlled by Wistia’s privacy policy.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Service Provider: Wistia, Inc.  \u003C\u002Fli>\n\u003Cli>Terms of Use: https:\u002F\u002Fwistia.com\u002Fterms  \u003C\u002Fli>\n\u003Cli>Privacy Policy: https:\u002F\u002Fwistia.com\u002Fprivacy\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>OptiPub API\u003C\u002Fh4>\n\u003Cp>Synchronizes content (publications, resources, videos, FAQs, authors, tags, categories, redirects) from the OptiPub platform to WordPress. Sends authenticated API requests with encrypted tokens to your configured OptiPub domain (typically \u003Ccode>https:\u002F\u002F\u003Cdomain>.app.optipub.com\u003C\u002Fcode>) via WP-Cron at configured intervals (default: every 5 minutes). Also creates edit links to OptiPub content management pages in WordPress admin.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Service Provider: OptiPub  \u003C\u002Fli>\n\u003Cli>Terms of Use & Privacy Policy: Please refer to your OptiPub service agreement for terms of use and privacy policy.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Third Party Libraries\u003C\u002Fh3>\n\u003Cp>This plugin includes one minified JavaScript library for video functionality:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Video.js v4.6.3\u003C\u002Fstrong> – Used for video player functionality\n\u003Cul>\n\u003Cli>\u003Cstrong>Source Code Repository:\u003C\u002Fstrong> https:\u002F\u002Fgithub.com\u002Fvideojs\u002Fvideo.js\u002Ftree\u002Fv4.6.3\u003C\u002Fli>\n\u003Cli>\u003Cstrong>License:\u003C\u002Fstrong> Apache 2.0\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Location in Plugin:\u003C\u002Fstrong> \u003Ccode>public\u002Fjs\u002Fvideo.js\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Documentation:\u003C\u002Fstrong> https:\u002F\u002Fdocs.videojs.com\u002F\u003C\u002Fli>\n\u003C\u002Ful>\n\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>The source code for this minified library is publicly available at the GitHub repository link above. This plugin does not include any custom build process – the minified file is used directly from the Video.js project.\u003C\u002Fp>\n\u003Ch3>Development Documentation\u003C\u002Fh3>\n\u003Cp>Technical documentation for developers working with the OptiPub plugin. Topics covered:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>OptiPub Introduction\u003C\u002Fli>\n\u003Cli>Prepare\u003C\u002Fli>\n\u003Cli>Installation\u003C\u002Fli>\n\u003Cli>Activation\u003C\u002Fli>\n\u003Cli>OptiPub Admin Page (Save Changes Button, Clear Data Button)\u003C\u002Fli>\n\u003Cli>Cron Job & Troubleshooting\u003C\u002Fli>\n\u003Cli>Plugin Configurations (wp-config.php, Configuring WP-Cron)\u003C\u002Fli>\n\u003Cli>Deactivation & Rescheduling the cron job\u003C\u002Fli>\n\u003Cli>Uninstallation\u003C\u002Fli>\n\u003Cli>Theme dependencies\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>OptiPub Introduction\u003C\u002Fh3>\n\u003Cp>OptiPub syncs OptiPub Resources to a WordPress installation. The plugin schedules the WP-Cron event \u003Ccode>optipub_sync\u003C\u002Fcode> to sync Publications, Resources, Videos, FAQs, Authors, Pages, Custom Content, Tags, Categories and Redirects.\u003C\u002Fp>\n\u003Cp>The plugin creates Custom Post Types (CPTs): \u003Ccode>Resources\u003C\u002Fcode>, \u003Ccode>Videos\u003C\u002Fcode>, \u003Ccode>FAQs\u003C\u002Fcode> and \u003Ccode>Authors\u003C\u002Fcode>. Resources synced to these post types store OptiPub metadata and properties in the \u003Ccode>wp_postmeta\u003C\u002Fcode> table. OptiPub Tags are saved as WordPress Tags. OptiPub Resource Categories are saved as WordPress Categories.\u003C\u002Fp>\n\u003Cp>WordPress Widgets can be created with OptiPub Custom Content from the \u003Ccode>OptiPub Admin\u003C\u002Fcode> page.\u003C\u002Fp>\n\u003Ch3>Prepare\u003C\u002Fh3>\n\u003Cp>From WordPress Admin: Settings > General, select timezone (recommended: ‘New York’) and click [Save Changes].\u003C\u002Fp>\n\u003Cp>OptiPub syncs with UTC but displays dates in EST. If you don’t select ‘New York’, website dates may differ from OptiPub dates. WordPress automatically converts \u003Ccode>post_date\u003C\u002Fcode> and \u003Ccode>post_modified\u003C\u002Fcode> to the selected timezone. Configure this before syncing data.\u003C\u002Fp>\n\u003Ch3>Bitnami permissions and configurations (Optional)\u003C\u002Fh3>\n\u003Cp>\u003Cstrong>Note:\u003C\u002Fstrong> This section is only required if you’re using Bitnami WordPress. Skip this if you’re using a standard WordPress installation.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Increase upload file size:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. \u003Ccode>sudo -i\u003C\u002Fcode>\u003Cbr \u002F>\n2. \u003Ccode>sudo nano \u002Fopt\u002Fbitnami\u002Fphp\u002Fetc\u002Fphp.ini\u003C\u002Fcode>\u003Cbr \u002F>\n3. Update \u003Ccode>upload_max_filesize\u003C\u002Fcode>, e.g. \u003Ccode>upload_max_filesize = 128M\u003C\u002Fcode>\u003Cbr \u002F>\n4. Restart: \u003Ccode>sudo \u002Fopt\u002Fbitnami\u002Fctlscript.sh restart\u003C\u002Fcode>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Set permissions before activation\u003C\u002Fstrong> (required for proper activation and uninstallation – vendor files need deletion permissions):\u003C\u002Fp>\n\u003Cp>Note: These commands apply to all WP plugins. Modify paths to target only OptiPub if needed.\u003C\u002Fp>\n\u003Col>\n\u003Cli>\u003Ccode>sudo find \u002Fhome\u002Fbitnami\u002Fapps\u002Fwordpress\u002Fhtdocs\u002Fwp-content\u002Fplugins\u002F -type d -exec chmod 775 {} \\;\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Ccode>sudo find \u002Fhome\u002Fbitnami\u002Fapps\u002Fwordpress\u002Fhtdocs\u002Fwp-content\u002Fplugins\u002F -type f -exec chmod 664 {} \\;\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>\u003Ccode>sudo chown -R bitnami:daemon \u002Fhome\u002Fbitnami\u002Fapps\u002Fwordpress\u002Fhtdocs\u002Fwp-content\u002Fplugins\u002F\u003C\u002Fcode>\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>This sets user\u002Fgroup to \u003Ccode>bitnami:daemon\u003C\u002Fcode>, file permissions to 664 (read\u002Fwrite for user\u002Fgroup, read for others), and folder permissions to 775 (read\u002Fwrite\u002Fexecute for user\u002Fgroup, read\u002Fexecute for others).\u003C\u002Fp>\n\u003Ch3>Activation\u003C\u002Fh3>\n\u003Cp>Activate from Plugins page. After activation, a green \u003Cstrong>OptiPub Admin\u003C\u002Fstrong> menu item appears in the left sidebar.\u003C\u002Fp>\n\u003Ch3>Activation Processes\u003C\u002Fh3>\n\u003Cp>During activation, three processes execute:\u003C\u002Fp>\n\u003Col>\n\u003Cli>\u003Cstrong>Override \u003Ccode>WP_CRON_LOCK_TIMEOUT\u003C\u002Fcode> constant\u003C\u002Fstrong> – Locates \u003Ccode>wp-config.php\u003C\u002Fcode> and overrides the constant. See \u003Ca href=\"#plugin-constants\" rel=\"nofollow ugc\">WP_CRON_LOCK_TIMEOUT\u003C\u002Fa>. Note: May fail in Bitnami if permissions aren’t set first.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Generate \u003Ccode>OPTIPUB_KEY\u003C\u002Fcode> encryption key\u003C\u002Fstrong> – Generates a random key stored in \u003Ccode>wp-config.php\u003C\u002Fcode> as \u003Ccode>OPTIPUB_KEY\u003C\u002Fcode>. Used to encrypt\u002Fdecrypt the API token during cron job execution.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Change permalink structure\u003C\u002Fstrong> – Changes permalink structure to \u003Ccode>\u002F%postname%\u002F\u003C\u002Fcode> to accommodate static pages with multiple slugs (e.g., \u003Ccode>https:\u002F\u002Fwww.energyandcapital.com\u002Fpubs-detailed\u002Fbab\u003C\u002Fcode> where \u003Ccode>pubs-detailed\u002Fbab\u003C\u002Fcode> is defined in \u003Ccode>\u002Fpages\u003C\u002Fcode> OptiPub API).\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Ch3>OptiPub Admin Page\u003C\u002Fh3>\n\u003Cp>The green menu icon opens the Admin Page for migrating data from the OptiPub API.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>OptiPub Sync Options:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. \u003Cstrong>OptiPub Domain\u003C\u002Fstrong> – HTTPS URL of the OptiPub API\u003Cbr \u002F>\n2. \u003Cstrong>API Token\u003C\u002Fstrong> – The provided API Token from OptiPub will be used to authenticate with the API. Encrypted and stored in database, decrypted for API calls\u003Cbr \u002F>\n3. \u003Cstrong>Open Graph Image Link\u003C\u002Fstrong> – Backup\u002Fdefault image URL. Access with:\u003Cbr \u002F>\n       \u003Ccode>function get_optipub_opengraph_image() {\u003Cbr \u002F>\n      return get_option(\\OptiPub\\Base\\Constants::OPTIPUB_OPENGRAPH_IMAGE_LINK);\u003Cbr \u002F>\n   }\u003C\u002Fcode>\u003Cbr \u002F>\n4. \u003Cstrong>WP Auth Token\u003C\u002Fstrong> – Create a WP Auth Token to authenticate subscriber logins through OptiPub\u003Cbr \u002F>\n5. \u003Cstrong>Home Page Template\u003C\u002Fstrong> – Template name from OptiPub:\u003Cbr \u002F>\n   – OptiPub > Administration > Templates – create template with \u003Ccode>.php\u003C\u002Fcode> extension (e.g., \u003Ccode>optipub_home_page.php\u003C\u002Fcode>)\u003Cbr \u002F>\n   – OptiPub > Content > Pages – create page with path \u003Ccode>\u002F\u003C\u002Fcode> using the template\u003Cbr \u002F>\n   – Optional: OptiPub > Content > Redirects – create redirect from \u003Ccode>domain.com\u002Fhome\u003C\u002Fcode> to \u003Ccode>https:\u002F\u002Fwww.domain.com\u002F\u003C\u002Fcode>\u003Cbr \u002F>\n6. \u003Cstrong>Publication Dropdown\u003C\u002Fstrong> – Generated after \u003Ccode>OptiPub Domain\u003C\u002Fcode> and \u003Ccode>API Token\u003C\u002Fcode> are provided and \u003Ccode>Save changes\u003C\u002Fcode> is clicked\u003Cbr \u002F>\n7. \u003Cstrong>Publication Domain Id\u003C\u002Fstrong> – Publication domain ID (integer) used to retrieve redirects\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Copy Files To Theme\u003C\u002Fstrong> (feature complete – documentation under construction)\u003Cbr \u002F>\nView more documentation in the plugin ‘OptiPub Admin’ page\u003C\u002Fp>\n\u003Col>\n\u003Cli>Files copied to \u003Ccode>[theme-directory]\u002Finc\u002Foptipub\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>Select file categories and click [Copy Files]\u003C\u002Fli>\n\u003Cli>Reference from current location or use as integration guide\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>If copying \u003Ccode>Helper Functions\u003C\u002Fcode>, copy content from \u003Ccode>[theme-directory]\u002Finc\u002Foptipub\u002Fphp\u002Fadd_to_bottom_of_functions.php.txt\u003C\u002Fcode> to your theme’s \u003Ccode>functions.php\u003C\u002Fcode>. \u003Ccode>include\u003C\u002Fcode> statements and filter\u002Faction calls are commented out. Review functions before uncommenting.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Custom Content Widget Sidebars\u003C\u002Fstrong> (feature complete – documentation under construction)\u003Cbr \u002F>\nView more documentation in the plugin ‘OptiPub Admin’ page\u003C\u002Fp>\n\u003Cp>Create custom content macro in OptiPub > Content > Custom Content. Custom Content syncs to WordPress as options.\u003C\u002Fp>\n\u003Cp>Click [Create New Widget]:\u003Cbr \u002F>\n– \u003Cstrong>Title\u003C\u002Fstrong> – WordPress Admin Console\u003Cbr \u002F>\n– \u003Cstrong>Sidebar ID\u003C\u002Fstrong> – Display widget in theme templates\u003Cbr \u002F>\n– \u003Cstrong>File Name\u003C\u002Fstrong> – WordPress Sidebar Widget content file\u003Cbr \u002F>\n– \u003Cstrong>Description\u003C\u002Fstrong> – WordPress Admin Console\u003Cbr \u002F>\n– \u003Cstrong>Custom Content\u003C\u002Fstrong> – OptiPub custom content macro name\u003Cbr \u002F>\n– \u003Cstrong>Class Name\u003C\u002Fstrong> – CSS class for styling\u003Cbr \u002F>\n– \u003Cstrong>Before Widget\u003C\u002Fstrong> – HTML before widget\u003Cbr \u002F>\n– \u003Cstrong>After Widget\u003C\u002Fstrong> – HTML after widget\u003Cbr \u002F>\n– \u003Cstrong>Before Title\u003C\u002Fstrong> – HTML before title (displays Title if used)\u003Cbr \u002F>\n– \u003Cstrong>After Title\u003C\u002Fstrong> – HTML after title (displays Title if used)\u003C\u002Fp>\n\u003Cp>\u003Cstrong>How OptiPub Custom Content creates WordPress Sidebar Widgets:\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>Widget files created at:\u003Cbr \u002F>\n    \u003Ccode>[theme-directory]\u002Finc\u002Foptipub\u002Fwidget-templates\u002F\u003C\u002Fcode>File Name\u003Ccode>\u003C\u002Fcode>\u003C\u002Fp>\n\u003Cp>Default content:\u003Cbr \u002F>\n    \u003Ccode>\u003C?php echo get_option('{$custom_content_name}'); ?>\u003C\u002Fcode>\u003C\u002Fp>\n\u003Cp>Include in theme templates:\u003Cbr \u002F>\n    \u003Ccode>if (is_active_sidebar('sidebar-id')) {\u003Cbr \u002F>\n   dynamic_sidebar('sidebar-id');\u003Cbr \u002F>\n}\u003C\u002Fcode>\u003C\u002Fp>\n\u003Ch3>Save Changes Button\u003C\u002Fh3>\n\u003Cp>Validates API Domain and token, then stores \u003Ccode>Optipub Domain\u003C\u002Fcode>, \u003Ccode>Api Token\u003C\u002Fcode>, \u003Ccode>Publication\u003C\u002Fcode>, \u003Ccode>Publication Domain\u003C\u002Fcode>, \u003Ccode>Header Pencil Ad Macro\u003C\u002Fcode>, \u003Ccode>Article bottom Ad Macro\u003C\u002Fcode>, \u003Ccode>Signup Sidebar Macro\u003C\u002Fcode> in \u003Ccode>wp_options\u003C\u002Fcode> table.\u003C\u002Fp>\n\u003Cp>Schedules cron job to run every 5 minutes if \u003Ccode>Optipub Domain\u003C\u002Fcode>, \u003Ccode>Api Token\u003C\u002Fcode>, and \u003Ccode>Publication\u003C\u002Fcode> are provided correctly.\u003C\u002Fp>\n\u003Cp>After saving, an API call fetches publication metadata. Fetched metadata appears in the WordPress admin left menu. New CPT links appear in \u003Cstrong>green\u003C\u002Fstrong> to differentiate from other CPTs.\u003C\u002Fp>\n\u003Ch3>Clear Data Button\u003C\u002Fh3>\n\u003Cp>Clears all imported posts (articles, resources, reports, etc.). Publication metadata remains, but imported posts are deleted. Stops and reschedules the cron job. Use to reset the plugin after errors.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Important Note:\u003C\u002Fstrong> \u003Cem>The clear button stops the current cron job, deletes all posts imported from the API, and reschedules the cron job.\u003C\u002Fem>\u003C\u002Fp>\n\u003Ch3>Cron Job\u003C\u002Fh3>\n\u003Cp>Syncs content from the OptiPub API. Scheduled to run every \u003Ccode>CRON_INTERVAL_IN_SECONDS\u003C\u002Fcode> after \u003Ccode>OptiPub Domain\u003C\u002Fcode>, \u003Ccode>API key\u003C\u002Fcode>, and \u003Ccode>Publication\u003C\u002Fcode> are selected.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>First run:\u003C\u002Fstrong> Loads all content for Custom Post Types, dynamic pages (nav menu pages like Videos, FAQs, Authors), static pages (from \u003Ccode>\u002Fcontents\u002Fpages\u003C\u002Fcode> endpoint), and Widget contents (from \u003Ccode>\u002Fcustom-contents\u003C\u002Fcode> endpoint).\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Subsequent runs:\u003C\u002Fstrong> Loads only new or updated content using the \u003Ccode>updated_at\u003C\u002Fcode> attribute and last cron run timestamp.\u003C\u002Fp>\n\u003Ch3>Troubleshooting the Cron Job\u003C\u002Fh3>\n\u003Cp>WP-CLI commands:\u003Cbr \u002F>\n– \u003Ccode>wp cron event list\u003C\u002Fcode> – Lists all cron jobs (\u003Ccode>optipub_sync\u003C\u002Fcode> is the plugin cron job)\u003Cbr \u002F>\n– \u003Ccode>wp cron event delete optipub_sync\u003C\u002Fcode> – Deletes the cron job. Use \u003Ccode>Save changes\u003C\u002Fcode> to reschedule.\u003C\u002Fp>\n\u003Ch3>Plugin Configurations\u003C\u002Fh3>\n\u003Cp>Constants control plugin behavior: Cron Job scheduling, error handling, widgetized areas, template directory paths.\u003C\u002Fp>\n\u003Cp>Constants defined in two places:\u003Cbr \u002F>\n1. \u003Ccode>wp-config.php\u003C\u002Fcode> – WordPress environment variables\u003Cbr \u002F>\n2. \u003Ccode>Plugin Constants\u003C\u002Fcode> ([plugin-directory]\u002Finc\u002FBase\u002FConstants.php) – Plugin runtime configuration\u003C\u002Fp>\n\u003Ch3>wp-config.php\u003C\u002Fh3>\n\u003Cp>\u003Cstrong>WP_CRON_LOCK_TIMEOUT\u003C\u002Fstrong> – Defines cron job execution period (default: 60 seconds, can be changed to 3600 seconds for 60 minutes). Plugin attempts to write this during activation. If it fails, cron job won’t schedule and error appears:\u003C\u002Fp>\n\u003Cpre>\u003Ccode>Could not activate Cron Job since WP_CRON_LOCK_TIMEOUT is smaller than the expected value of: 3000 (e.x);\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Ch3>Configuring WP-Cron\u003C\u002Fh3>\n\u003Cp>WP-Cron documentation: https:\u002F\u002Fdeveloper.wordpress.org\u002Fplugins\u002Fcron\u002F\u003C\u002Fp>\n\u003Cp>Configuration in \u003Ccode>[plugin-directory]\u002Finc\u002FBase\u002FConstants.php\u003C\u002Fcode>:\u003C\u002Fp>\n\u003Col>\n\u003Cli>\n\u003Cp>\u003Cstrong>CRON_INTERVAL_IN_SECONDS\u003C\u002Fstrong> – Default: 60 – Interval in seconds for \u003Ccode>optipub_sync\u003C\u002Fcode> wp-cron job. Creates a lock option in \u003Ccode>wp_options\u003C\u002Fcode> table; cron won’t run again until it finishes and deletes the option.\u003C\u002Fp>\n\u003C\u002Fli>\n\u003Cli>\n\u003Cp>\u003Cstrong>WP_CRON_LOCK_TIMEOUT\u003C\u002Fstrong> – Default: 3600 – Changes WP-Cron timeout in \u003Ccode>wp-config.php\u003C\u002Fcode>:\u003Cbr \u002F>\n   \u003Ccode>define( 'WP_CRON_LOCK_TIMEOUT', 3600 );\u003C\u002Fcode>\u003Cbr \u002F>\nPlugin updates this during Activation, when clearing plugin data, or when changing Publication.\u003C\u002Fp>\n\u003Cp>NOTE: WP-Cron checks for scheduled jobs on every page load. For more consistent intervals, create a system cron job (requires server access).\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Crontab in Linux:\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>PHP Command:\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cpre>\u003Ccode>* * * * * HTTP_HOST=www.domain.com $(which php) \u002Fopt\u002Fbitnami\u002Fwordpress\u002Fwp-cron.php >> \u002Fpath\u002Fto\u002Ffile.log 2>&1\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Cp>Configure \u003Ccode>HTTP_HOST\u003C\u002Fcode> to your site domain.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>WP-CLI:\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cpre>\u003Ccode>* * * * * sudo wp cron event run optipub_sync\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Cp>Note: Cannot log output and less reliable than PHP command.\u003C\u002Fp>\n\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Ch3>Deactivation\u003C\u002Fh3>\n\u003Cp>Deactivate from Plugins page. Deactivation pauses execution, temporarily disables custom post types and admin page, and stops cron job schedule. Cron job won’t reschedule on reactivation. If cron is running during deactivation, it finishes its job, then gets deleted on next run.\u003C\u002Fp>\n\u003Ch3>Rescheduling the cron job\u003C\u002Fh3>\n\u003Cp>After deactivation clears the cron job, reschedule via \u003Cstrong>Save Changes\u003C\u002Fstrong> button (even without data changes).\u003C\u002Fp>\n\u003Ch3>Uninstallation\u003C\u002Fh3>\n\u003Cp>Uninstall from WP Plugin page. Deactivate first to enable delete option.\u003C\u002Fp>\n\u003Cp>Uninstallation removes all plugin directory files. During uninstall, database commands delete all plugin-created content. Details in \u003Ccode>uninstall.php\u003C\u002Fcode> file.\u003C\u002Fp>\n\u003Ch3>Theme dependencies\u003C\u002Fh3>\n\u003Cp>Content loaded by the plugin is displayed via custom WP theme templates. Theme must provide templates for dynamic pages and widgets, and register\u002Fdisplay widgets. Page templates in theme root directory. Widget templates in theme \u003Ccode>widget-templates\u003C\u002Fcode> directory.\u003C\u002Fp>\n\u003Cp>Templates in plugin \u003Ccode>\u002Ftemplates\u003C\u002Fcode> directory are not used by the plugin but serve as guides for retrieving content from the WP Database. Only \u003Ccode>optipub_admin.php\u003C\u002Fcode> in \u003Ccode>\u002Ftemplates\u003C\u002Fcode> is used (decorates the Admin page).\u003C\u002Fp>\n\u003Cp>Theme must know Widget area IDs to register them in \u003Ccode>functions.php\u003C\u002Fcode>. IDs are documented above and found in plugin \u003Ccode>Constants.php\u003C\u002Fcode> class.\u003C\u002Fp>\n\u003Cp>template-parts\u002Farchives\u002F\u003Cbr \u002F>\n   optipub-filters.php\u003Cbr \u002F>\n   optipub-pagination_params.php\u003C\u002Fp>\n\u003Cp>template-parts\u002Fvideos\u002F\u003Cbr \u002F>\n   mv display.php videos_handler.php\u003C\u002Fp>\n","Sync OptiPub content to WordPress with automated cron jobs and custom post types.",481,"6.8.5",[107,108,20,98,22],"api-integration","content-sync","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Foptipub.1.0.14.zip","2026-03-15T10:48:56.248Z",{"slug":112,"name":113,"version":114,"author":115,"author_profile":116,"description":117,"short_description":118,"active_installs":119,"downloaded":120,"rating":121,"num_ratings":122,"last_updated":123,"tested_up_to":124,"requires_at_least":15,"requires_php":125,"tags":126,"homepage":128,"download_link":129,"security_score":130,"vuln_count":11,"unpatched_count":11,"last_vuln_date":26,"fetched_at":27},"custom-post-type-widgets","Custom Post Type Widgets","1.5.2","thingsym","https:\u002F\u002Fprofiles.wordpress.org\u002Fthingsym\u002F","\u003Cp>Custom Post Type Widgets plugin adds default custom post type widgets.\u003Cbr \u002F>\nYou can filter by registered Custom Post Type or Taxonomy on widgets.\u003C\u002Fp>\n\u003Ch4>Descriptions of Widgets\u003C\u002Fh4>\n\u003Ch4>Recent Posts (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a list of the most recent custom posts.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the list of recent custom posts.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Post Type\u003C\u002Fstrong> – if selected, filter by a custom post type. (e.g. post).\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Number of posts to show (at most 15)\u003C\u002Fstrong> – enter the number of posts to display.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Display post date?\u003C\u002Fstrong> – if checked, display post date.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Archives (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a list of archive links for each month that has custom posts.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the list of archive links.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Post Type\u003C\u002Fstrong> – if selected, filter by a custom post type. (e.g. post).\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Archive Type\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Display as dropdown\u003C\u002Fstrong> – if checked, this box causes the archives to be displayed in a drop-down box.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Show post counts\u003C\u002Fstrong> – if checked, this box causes a count of the number of posts for each archive period.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Order\u003C\u002Fstrong>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Categories (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a list of categories that has custom posts.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the list of categories.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Taxonomy\u003C\u002Fstrong> – if selected, filter a custom taxonomy (e.g. category).\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Display as dropdown\u003C\u002Fstrong> – if checked, this box causes the categories to be displayed in a dropdown box.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Show post counts\u003C\u002Fstrong> – if checked, this box causes the count of the number of posts to display with each category.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Show hierarchy\u003C\u002Fstrong> – if checked, shows parent\u002Fchild relationships in an indented manner.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Calendar (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a calendar of the current month.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the calendar.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Post Type\u003C\u002Fstrong> – if selected, filter by a custom post type. (e.g. post).\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Recent Comments (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a list of the most recent comments.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the list of recent comments.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Post Type\u003C\u002Fstrong> – if selected, filter by a custom post type. (e.g. post).\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Number of comments to show (at most 15)\u003C\u002Fstrong> – enter the number of comments to be displayed.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Tag Cloud (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>display a list of the top 45 that has used in a tag cloud.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the tag cloud.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Taxonomy\u003C\u002Fstrong> – if selected, filter a custom taxonomy (e.g. post_tag).\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Show tag counts\u003C\u002Fstrong> – if checked, this box causes the count of the number of tags to display with each tag.\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Search (Custom Post Type)\u003C\u002Fh4>\n\u003Cp>A search form for your site.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Cstrong>Title\u003C\u002Fstrong> – description that appears over the search.\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Post Type\u003C\u002Fstrong> – if selected, filter by a custom post type. (e.g. post).\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Hooks\u003C\u002Fh4>\n\u003Cp>Custom Post Type Widgets has its own hooks. See the reference for details.\u003C\u002Fp>\n\u003Cp>Reference: \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets#hooks\" rel=\"nofollow ugc\">https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets#hooks\u003C\u002Fa>\u003C\u002Fp>\n\u003Ch4>Support\u003C\u002Fh4>\n\u003Cp>If you have any trouble, you can use the forums or report bugs.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Forum: \u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Fcustom-post-type-widgets\u002F\" rel=\"ugc\">https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Fcustom-post-type-widgets\u002F\u003C\u002Fa>\u003C\u002Fli>\n\u003Cli>Issues: \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\u002Fissues\" rel=\"nofollow ugc\">https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\u002Fissues\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Contribution\u003C\u002Fh4>\n\u003Cp>Small patches and bug reports can be submitted a issue tracker in Github. Forking on Github is another good way. You can send a pull request.\u003C\u002Fp>\n\u003Cp>Translating a plugin takes a lot of time, effort, and patience. I really appreciate the hard work from these contributors.\u003C\u002Fp>\n\u003Cp>If you have created or updated your own language pack, you can send gettext PO and MO files to author. I can bundle it into plugin.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\" rel=\"nofollow ugc\">VCS – GitHub\u003C\u002Fa>\u003C\u002Fli>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fplugins\u002Fcustom-post-type-widgets\u002F\" rel=\"ugc\">Homepage – WordPress Plugin\u003C\u002Fa>\u003C\u002Fli>\n\u003Cli>\u003Ca href=\"https:\u002F\u002Ftranslate.wordpress.org\u002Fprojects\u002Fwp-plugins\u002Fcustom-post-type-widgets\" rel=\"nofollow ugc\">Translate Custom Post Type Widgets into your language.\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>You can also contribute by answering issues on the forums.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>Forum: \u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Fcustom-post-type-widgets\u002F\" rel=\"ugc\">https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Fcustom-post-type-widgets\u002F\u003C\u002Fa>\u003C\u002Fli>\n\u003Cli>Issues: \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\u002Fissues\" rel=\"nofollow ugc\">https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\u002Fissues\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Patches and Bug Fixes\u003C\u002Fh4>\n\u003Cp>Forking on Github is another good way. You can send a pull request.\u003C\u002Fp>\n\u003Col>\n\u003Cli>Fork \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\" rel=\"nofollow ugc\">Custom Post Type Widgets\u003C\u002Fa> from GitHub repository\u003C\u002Fli>\n\u003Cli>Create a feature branch: git checkout -b my-new-feature\u003C\u002Fli>\n\u003Cli>Commit your changes: git commit -am ‘Add some feature’\u003C\u002Fli>\n\u003Cli>Push to the branch: git push origin my-new-feature\u003C\u002Fli>\n\u003Cli>Create new Pull Request\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Ch4>Contribute guidlines\u003C\u002Fh4>\n\u003Cp>If you would like to contribute, here are some notes and guidlines.\u003C\u002Fp>\n\u003Cul>\n\u003Cli>All development happens on the \u003Cstrong>develop\u003C\u002Fstrong> branch, so it is always the most up-to-date\u003C\u002Fli>\n\u003Cli>The \u003Cstrong>master\u003C\u002Fstrong> branch only contains tagged releases\u003C\u002Fli>\n\u003Cli>If you are going to be submitting a pull request, please submit your pull request to the \u003Cstrong>develop\u003C\u002Fstrong> branch\u003C\u002Fli>\n\u003Cli>See about \u003Ca href=\"https:\u002F\u002Fhelp.github.com\u002Farticles\u002Ffork-a-repo\u002F\" rel=\"nofollow ugc\">forking\u003C\u002Fa> and \u003Ca href=\"https:\u002F\u002Fhelp.github.com\u002Farticles\u002Fusing-pull-requests\u002F\" rel=\"nofollow ugc\">pull requests\u003C\u002Fa>\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Test Matrix\u003C\u002Fh4>\n\u003Cp>For operation compatibility between PHP version and WordPress version, see below \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets\u002Factions\" rel=\"nofollow ugc\">Github Actions\u003C\u002Fa>.\u003C\u002Fp>\n","Custom Post Type Widgets plugin adds default custom post type widgets.",10000,213072,96,14,"2024-08-22T07:06:00.000Z","6.6.5","5.6",[19,127,21,22],"taxonomy","https:\u002F\u002Fgithub.com\u002Fthingsym\u002Fcustom-post-type-widgets","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fcustom-post-type-widgets.1.5.2.zip",92,{"attackSurface":132,"codeSignals":144,"taintFlows":179,"riskAssessment":180,"analyzedAt":190},{"hooks":133,"ajaxHandlers":140,"restRoutes":141,"shortcodes":142,"cronEvents":143,"entryPointCount":11,"unprotectedCount":11},[134],{"type":135,"name":136,"callback":137,"file":138,"line":139},"action","widgets_init","register_cpt_recent_entries_widgets","cpt-recent-entries.php",16,[],[],[],[],{"dangerousFunctions":145,"sqlUsage":146,"outputEscaping":148,"fileOperations":11,"externalRequests":11,"nonceChecks":11,"capabilityChecks":11,"bundledLibraries":178},[],{"prepared":11,"raw":11,"locations":147},[],{"escaped":149,"rawEcho":150,"locations":151},3,15,[152,155,157,159,161,163,165,166,167,169,171,172,174,176,177],{"file":138,"line":153,"context":154},53,"raw output",{"file":138,"line":156,"context":154},57,{"file":138,"line":158,"context":154},68,{"file":138,"line":160,"context":154},80,{"file":138,"line":162,"context":154},117,{"file":138,"line":164,"context":154},118,{"file":138,"line":164,"context":154},{"file":138,"line":164,"context":154},{"file":138,"line":168,"context":154},123,{"file":138,"line":170,"context":154},124,{"file":138,"line":170,"context":154},{"file":138,"line":173,"context":154},141,{"file":138,"line":175,"context":154},142,{"file":138,"line":175,"context":154},{"file":138,"line":175,"context":154},[],[],{"summary":181,"deductions":182},"Based on the static analysis and vulnerability history, the \"cpt-recent-entries-widgets\" plugin version 1.0.0 exhibits a generally strong security posture. The absence of any identified CVEs, coupled with a lack of critical or high-severity taint flows, suggests a mature development process for this version. The plugin also avoids common pitfalls such as raw SQL queries, external HTTP requests, and file operations, indicating a focus on secure coding practices.  Furthermore, the complete absence of an attack surface from AJAX handlers, REST API routes, shortcodes, and cron events significantly reduces the potential for exploitation.\n\nHowever, a notable concern arises from the low percentage of properly escaped output (17%). This indicates that a significant portion of user- or data-generated content may not be adequately sanitized before being displayed to users, potentially leading to Cross-Site Scripting (XSS) vulnerabilities. While the current analysis did not uncover specific XSS flaws, this weakness represents a substantial risk that could be exploited if user-supplied data is ever incorporated into the plugin's output. The lack of nonce and capability checks, while not directly exploitable in this analysis due to the absence of an attack surface, are fundamental security mechanisms that should ideally be implemented for any plugin functionality that interacts with user input or performs sensitive actions.\n\nIn conclusion, while the plugin's foundation appears solid with no history of vulnerabilities and a minimal attack surface, the insufficient output escaping is a critical area that requires immediate attention. Addressing this weakness will significantly bolster the plugin's security and prevent potential XSS attacks. The absence of explicit authentication checks on entry points, even though currently moot, suggests a potential area for improvement in defensive coding.",[183,185,188],{"reason":184,"points":150},"Low percentage of properly escaped output",{"reason":186,"points":187},"Missing nonce checks",5,{"reason":189,"points":187},"Missing capability checks","2026-03-17T07:34:27.832Z",{"wat":192,"direct":197},{"assetPaths":193,"generatorPatterns":194,"scriptPaths":195,"versionParams":196},[],[],[],[],{"cssClasses":198,"htmlComments":200,"htmlAttributes":201,"restEndpoints":202,"jsGlobals":203,"shortcodeOutput":204},[199],"widget_cpt_recent_entries",[],[],[],[],[]]