{"id":280789,"date":"2026-04-30T18:37:38","date_gmt":"2026-04-30T18:37:38","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/postgate\/"},"modified":"2026-04-30T22:44:23","modified_gmt":"2026-04-30T22:44:23","slug":"postgate","status":"publish","type":"plugin","link":"https:\/\/wordpress.org\/plugins\/postgate\/","author":23448681,"comment_status":"closed","ping_status":"closed","template":"","meta":{"version":"1.0.3","stable_tag":"1.0.3","tested":"6.9.4","requires":"6.2","requires_php":"7.4","requires_plugins":null,"header_name":"PostGate - Paywall & Content Monetization","header_author":"QodeSphere","header_description":"Monetize your WordPress content with precision using flexible paywalls, one-time purchases, and subscriptions powered by Stripe.","assets_banners_color":"66bba4","last_updated":"2026-04-30 22:44:23","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/www.qodesphere.com\/plugins\/postage\/","header_author_uri":"https:\/\/qodesphere.com","rating":0,"author_block_rating":0,"active_installs":0,"downloads":201,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.0":{"tag":"1.0.0","author":"qodesphere","date":"2026-04-30 18:37:26"},"1.0.1":{"tag":"1.0.1","author":"qodesphere","date":"2026-04-30 21:18:56"},"1.0.2":{"tag":"1.0.2","author":"qodesphere","date":"2026-04-30 21:49:07"},"1.0.3":{"tag":"1.0.3","author":"qodesphere","date":"2026-04-30 22:44:23"}},"upgrade_notice":{"1.0.3":"<p>Maintenance release: Simplified deployment pipeline and improved vendor directory handling.<\/p>","1.0.2":"<p>Important update: Fixes vendor file deployment to WordPress.org. Resolves Stripe SDK loading issues reported in 1.0.1.<\/p>","1.0.1":"<p>Critical update: Fixes Stripe SDK loading issues in WordPress.org deployment. Highly recommended for all users.<\/p>"},"ratings":[],"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3519880,"resolution":"128x128","location":"assets","locale":""},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3519880,"resolution":"256x256","location":"assets","locale":""}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3519880,"resolution":"1544x500","location":"assets","locale":""},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3519880,"resolution":"772x250","location":"assets","locale":""}},"assets_blueprints":{},"all_blocks":{"postgate\/lock-block":{"$schema":"https:\/\/schemas.wp.org\/trunk\/block.json","apiVersion":3,"name":"postgate\/lock-block","version":"1.0.0","title":"PostGate Lock","category":"widgets","icon":"lock","description":"Lock specific nested content behind a paywall or login requirement.","textdomain":"postgate","supports":{"html":false,"align":["wide","full"]},"attributes":{"lockMode":{"type":"string","default":"paywall"},"productIds":{"type":"array","default":[]},"paywallTemplate":{"type":"string","default":"compact"},"clientId":{"type":"string"}},"usesContext":["postId"],"providesContext":{"postgate\/lockMode":"lockMode"},"editorScript":"file:.\/index.js","editorStyle":"file:.\/style-index.css"}},"tagged_versions":["1.0.0","1.0.1","1.0.2","1.0.3"],"block_files":[],"assets_screenshots":{"screenshot-1.png":{"filename":"screenshot-1.png","revision":3519880,"resolution":"1","location":"assets","locale":""},"screenshot-10.png":{"filename":"screenshot-10.png","revision":3519880,"resolution":"10","location":"assets","locale":""},"screenshot-11.png":{"filename":"screenshot-11.png","revision":3519880,"resolution":"11","location":"assets","locale":""},"screenshot-12.png":{"filename":"screenshot-12.png","revision":3519880,"resolution":"12","location":"assets","locale":""},"screenshot-2.png":{"filename":"screenshot-2.png","revision":3519880,"resolution":"2","location":"assets","locale":""},"screenshot-3.png":{"filename":"screenshot-3.png","revision":3519880,"resolution":"3","location":"assets","locale":""},"screenshot-4.png":{"filename":"screenshot-4.png","revision":3519880,"resolution":"4","location":"assets","locale":""},"screenshot-5.png":{"filename":"screenshot-5.png","revision":3519880,"resolution":"5","location":"assets","locale":""},"screenshot-6.png":{"filename":"screenshot-6.png","revision":3519880,"resolution":"6","location":"assets","locale":""},"screenshot-7.png":{"filename":"screenshot-7.png","revision":3519880,"resolution":"7","location":"assets","locale":""},"screenshot-8.png":{"filename":"screenshot-8.png","revision":3519880,"resolution":"8","location":"assets","locale":""},"screenshot-9.png":{"filename":"screenshot-9.png","revision":3519880,"resolution":"9","location":"assets","locale":""}},"screenshots":{"1":"Dashboard overview with revenue and order statistics","2":"General settings: site-wide lock, post types, lock mode, and bypass roles","3":"Stripe Connect integration with live and sandbox modes","4":"Product synchronization from Stripe with automatic updates","5":"Appearance settings: preview mode, paywall customization","6":"Post editor sidebar with granular lock controls","7":"Compact paywall template with pricing options","8":"Classic paywall template with detailed pricing display","9":"Block-level content locking within posts","10":"Order management with purchase history","11":"Webhook configuration for Stripe integration","12":"Login gate template for members-only content"},"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[1932,1336,12688,5349,448],"plugin_category":[41,45,58],"plugin_contributors":[261583],"plugin_business_model":[],"class_list":["post-280789","plugin","type-plugin","status-publish","hentry","plugin_tags-membership","plugin_tags-paid-content","plugin_tags-paywall","plugin_tags-stripe","plugin_tags-subscription","plugin_category-communication","plugin_category-ecommerce","plugin_category-user-management","plugin_contributors-qodesphere","plugin_committers-qodesphere"],"banners":{"banner":"https:\/\/ps.w.org\/postgate\/assets\/banner-772x250.png?rev=3519880","banner_2x":"https:\/\/ps.w.org\/postgate\/assets\/banner-1544x500.png?rev=3519880","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/postgate\/assets\/icon-128x128.png?rev=3519880","icon_2x":"https:\/\/ps.w.org\/postgate\/assets\/icon-256x256.png?rev=3519880","generated":false},"screenshots":[{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-1.png?rev=3519880","caption":"Dashboard overview with revenue and order statistics"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-2.png?rev=3519880","caption":"General settings: site-wide lock, post types, lock mode, and bypass roles"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-3.png?rev=3519880","caption":"Stripe Connect integration with live and sandbox modes"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-4.png?rev=3519880","caption":"Product synchronization from Stripe with automatic updates"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-5.png?rev=3519880","caption":"Appearance settings: preview mode, paywall customization"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-6.png?rev=3519880","caption":"Post editor sidebar with granular lock controls"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-7.png?rev=3519880","caption":"Compact paywall template with pricing options"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-8.png?rev=3519880","caption":"Classic paywall template with detailed pricing display"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-9.png?rev=3519880","caption":"Block-level content locking within posts"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-10.png?rev=3519880","caption":"Order management with purchase history"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-11.png?rev=3519880","caption":"Webhook configuration for Stripe integration"},{"src":"https:\/\/ps.w.org\/postgate\/assets\/screenshot-12.png?rev=3519880","caption":"Login gate template for members-only content"}],"raw_content":"<!--section=description-->\n<h3>The Complete WordPress Paywall Plugin<\/h3>\n\n<p><strong>PostGate<\/strong> is the most flexible WordPress paywall plugin for content creators, publishers, and membership site owners. Whether you want to add a paywall to your entire site, specific categories, individual posts, or even blocks within posts, PostGate gives you complete control over your WordPress content monetization strategy.<\/p>\n\n<h3>WordPress Content Monetization Made Simple<\/h3>\n\n<p>PostGate enables you to monetize premium content through flexible payment options. Gate content behind paywalls, sell one-time access to articles, create membership subscriptions, or mix payment models to maximize your revenue.<\/p>\n\n<h3>Key Features<\/h3>\n\n<p><strong>Flexible Content Protection<\/strong>\n- <strong>Site-Wide Locking<\/strong>: Gate your entire website behind a paywall or login requirement\n- <strong>Post-Level Control<\/strong>: Lock individual posts with custom pricing and access rules\n- <strong>Category-Based Access<\/strong>: Apply payment requirements to entire categories or taxonomies\n- <strong>Block-Level Gating<\/strong>: Lock specific sections within posts using the PostGate Lock Block\n- <strong>Granular Override System<\/strong>: Post-level settings override category rules, which override global settings<\/p>\n\n<p><strong>Multiple Monetization Options<\/strong>\n- <strong>One-Time Purchases<\/strong>: Sell individual articles or content pieces for single payments\n- <strong>Recurring Subscriptions<\/strong>: Offer monthly, yearly, or custom subscription plans\n- <strong>Mixed Pricing Models<\/strong>: Combine one-time and subscription options for the same content\n- <strong>Flexible Pricing<\/strong>: Set different prices per post, category, or site-wide\n- <strong>Multiple Product Options<\/strong>: Present users with various pricing tiers to choose from<\/p>\n\n<p><strong>Take Complete Control of Content Access<\/strong>\n- <strong>Protect free content<\/strong>: Let only registered members access content without requiring payment\n- <strong>Monetize premium content<\/strong>: Require payment or active subscriptions to unlock your best content\n- <strong>Grant VIP access<\/strong>: Automatically give administrators, editors, or custom roles instant access\n- <strong>Seamless post-purchase experience<\/strong>: Automatically unlock content after successful payment<\/p>\n\n<p><strong>Professional Paywall Templates<\/strong>\n- <strong>Compact Layout<\/strong>: Streamlined design optimized for mobile devices and quick conversions\n- <strong>Classic Layout<\/strong>: Traditional paywall with detailed pricing information and descriptions\n- <strong>Fully Customizable<\/strong>: Override templates in your theme for complete design control\n- <strong>SEO-Friendly<\/strong>: Preview content before the paywall for search engine crawlers<\/p>\n\n<p><strong>Content Preview Options<\/strong>\n- <strong>Paragraph Mode<\/strong>: Show first N paragraphs as a teaser\n- <strong>Word Count Mode<\/strong>: Display first N words with automatic truncation\n- <strong>Customizable Limits<\/strong>: Set preview length per post or globally\n- <strong>Smart Truncation<\/strong>: Intelligent content splitting that respects HTML structure<\/p>\n\n<p><strong>Seamless Stripe Integration<\/strong>\n- <strong>Stripe Connect<\/strong>: Secure OAuth connection with your Stripe account\n- <strong>Live &amp; Sandbox Modes<\/strong>: Test your paywall before going live\n- <strong>Automatic Webhook Handling<\/strong>: Real-time payment processing and access granting\n- <strong>Secure Checkout<\/strong>: Users complete payments on Stripe-hosted checkout pages\n- <strong>Multiple Currencies<\/strong>: Support for all Stripe-supported currencies<\/p>\n\n<p><strong>Developer-Friendly Architecture<\/strong>\n- <strong>Template System<\/strong>: Override any template in your theme\n- <strong>REST API Endpoints<\/strong>: Integrate with external applications\n- <strong>Action &amp; Filter Hooks<\/strong>: Extend functionality with custom code\n- <strong>Modern React Admin<\/strong>: Intuitive settings interface built with React\n- <strong>Gutenberg Integration<\/strong>: Native block editor support with custom blocks\n- <strong>Well-Documented Code<\/strong>: Comprehensive inline documentation following WordPress standards<\/p>\n\n<h3>Use Cases<\/h3>\n\n<ul>\n<li><strong>Content Publishers<\/strong>: Monetize premium articles, investigative journalism, or exclusive reports<\/li>\n<li><strong>Membership Sites<\/strong>: Create tiered membership levels with subscription-based access<\/li>\n<li><strong>Online Courses<\/strong>: Lock course modules and lessons behind payment gates<\/li>\n<li><strong>Digital Downloads<\/strong>: Sell access to downloadable content like ebooks, templates, or resources<\/li>\n<li><strong>Professional Blogs<\/strong>: Offer premium content alongside free articles<\/li>\n<li><strong>News Publications<\/strong>: Implement metered paywalls or hard paywalls for news content<\/li>\n<li><strong>Tutorial Sites<\/strong>: Gate advanced tutorials while keeping beginner content free<\/li>\n<li><strong>Research Platforms<\/strong>: Monetize research papers, case studies, or whitepapers<\/li>\n<\/ul>\n\n<h3>How It Works<\/h3>\n\n<ol>\n<li><strong>Connect Stripe<\/strong>: Link your Stripe account using secure OAuth authentication<\/li>\n<li><strong>Configure Settings<\/strong>: Choose between site-wide locking, selective post types, or manual control<\/li>\n<li><strong>Set Products<\/strong>: Create and sync products from your Stripe dashboard<\/li>\n<li><strong>Protect Content<\/strong>: Apply paywall protection globally, by category, per post, or at block level<\/li>\n<li><strong>Customize Appearance<\/strong>: Choose paywall templates and customize preview settings<\/li>\n<li><strong>Start Earning<\/strong>: Users purchase access and are automatically granted content access<\/li>\n<\/ol>\n\n<h3>Security &amp; Privacy<\/h3>\n\n<p>PostGate is built with security best practices in mind:\n- All payment processing handled by Stripe (PCI DSS compliant)\n- Webhook signature verification prevents unauthorized access grants\n- Nonce verification on all AJAX requests\n- Sanitization and validation of all user inputs\n- Role and capability checks throughout the plugin\n- Secure OAuth flow for Stripe account connection<\/p>\n\n<h3>Internationalization<\/h3>\n\n<p>PostGate is translation-ready and includes:\n- WordPress.org translation compatibility\n- Text domain: <code>postgate<\/code>\n- RTL language support ready<\/p>\n\n<h3>Dashboard &amp; Analytics<\/h3>\n\n<ul>\n<li><strong>Order Management<\/strong>: View all purchases and subscriptions<\/li>\n<li><strong>Revenue Tracking<\/strong>: Monitor your earnings over time<\/li>\n<li><strong>Access Grants Overview<\/strong>: See which users have access to what content<\/li>\n<\/ul>\n\n<h3>Customization Options<\/h3>\n\n<ul>\n<li><strong>Paywall Appearance<\/strong>: Customize badge, title, description, and button text<\/li>\n<li><strong>Login Gate Settings<\/strong>: Configure login-specific messaging and registration links<\/li>\n<li><strong>Preview Control<\/strong>: Fine-tune how much content appears before the paywall<\/li>\n<li><strong>Content Before\/After Products<\/strong>: Add custom HTML content around product options<\/li>\n<li><strong>Post-Purchase Behavior<\/strong>: Choose where users land after completing a purchase<\/li>\n<\/ul>\n\n<h3>What's New in Version 1.0.0<\/h3>\n\n<ul>\n<li>Initial release with complete paywall functionality<\/li>\n<li>Stripe Connect integration with OAuth authentication<\/li>\n<li>One-time purchases and recurring subscriptions support<\/li>\n<li>Site-wide, category-level, post-level, and block-level content protection<\/li>\n<li>Two professional paywall templates (Compact and Classic)<\/li>\n<li>Comprehensive access management system<\/li>\n<li>Preview\/teaser content with paragraph or word-based truncation<\/li>\n<li>Role-based bypass system<\/li>\n<li>React-based admin interface<\/li>\n<li>REST API for orders and dashboard analytics<\/li>\n<li>Comprehensive webhook handling for Stripe events<\/li>\n<li>Internationalization support<\/li>\n<\/ul>\n\n<h3>Additional Information<\/h3>\n\n<p><strong>Links<\/strong>\n* <a href=\"https:\/\/qodesphere.tawk.help\/article\/quick-start-guide?utm_source=wporg&amp;utm_medium=readme&amp;utm_campaign=postgate\">Read Our Quick Start Guide<\/a>\n* <a href=\"https:\/\/qodesphere.tawk.help\/category\/postgate-documentation?utm_source=wporg&amp;utm_medium=readme&amp;utm_campaign=postgate\">Documentation<\/a>\n* <a href=\"https:\/\/wordpress.org\/support\/plugin\/postgate\">Support Forum<\/a><\/p>\n\n<p><strong>Credits<\/strong>\nPostGate is developed and maintained by QodeSphere. Special thanks to the WordPress and Stripe developer communities for their invaluable tools and resources.<\/p>\n\n<p><strong>Privacy Policy<\/strong>\nPostGate itself does not collect any user data. Payment processing is handled entirely by Stripe. Please review Stripe's privacy policy at stripe.com\/privacy for information about how payment data is handled.<\/p>\n\n<!--section=installation-->\n<h3>Automatic Installation<\/h3>\n\n<ol>\n<li>Log in to your WordPress admin dashboard<\/li>\n<li>Navigate to <strong>Plugins &gt; Add New<\/strong><\/li>\n<li>Search for \"PostGate\"<\/li>\n<li>Click <strong>Install Now<\/strong> next to the PostGate plugin<\/li>\n<li>After installation, click <strong>Activate<\/strong><\/li>\n<li>Go to <strong>PostGate &gt; Settings<\/strong> to configure the plugin<\/li>\n<\/ol>\n\n<h3>Manual Installation<\/h3>\n\n<ol>\n<li>Download the <code>postgate.zip<\/code> file<\/li>\n<li>Log in to your WordPress admin dashboard<\/li>\n<li>Navigate to <strong>Plugins &gt; Add New &gt; Upload Plugin<\/strong><\/li>\n<li>Click <strong>Choose File<\/strong> and select the downloaded <code>postgate.zip<\/code> file<\/li>\n<li>Click <strong>Install Now<\/strong><\/li>\n<li>After installation, click <strong>Activate Plugin<\/strong><\/li>\n<li>Go to <strong>PostGate &gt; Settings<\/strong> to configure the plugin<\/li>\n<\/ol>\n\n<h3>Configuration<\/h3>\n\n<p><strong>Step 1: Connect Stripe Account<\/strong>\n1. Navigate to <strong>PostGate &gt; Settings &gt; Payments<\/strong>\n1. Click <strong>Connect with Stripe<\/strong> button\n1. Log in to your Stripe account (or create one if needed)\n1. Authorize PostGate to access your Stripe account\n1. You'll be redirected back to your WordPress site<\/p>\n\n<p><strong>Step 2: Configure Webhook<\/strong>\n1. Copy the webhook URL from <strong>PostGate &gt; Settings &gt; Payments<\/strong>\n1. Add this URL to your Stripe account webhook endpoints\n1. Select all checkout and payment events\n1. Copy the webhook signing secret back to PostGate settings\n1. Save your settings<\/p>\n\n<p><strong>Step 3: Sync Stripe Products<\/strong>\n1. Create products and prices in your Stripe dashboard\n1. Return to <strong>PostGate &gt; Settings &gt; Payments<\/strong>\n1. Click <strong>Fetch &amp; Sync Products<\/strong> button\n1. Your Stripe products will be available to select when protecting content<\/p>\n\n<p><strong>Step 4: Configure Access Rules<\/strong>\n1. Go to <strong>PostGate &gt; Settings &gt; General<\/strong>\n1. Choose <strong>Lock Entire Site<\/strong> for site-wide protection, or\n1. Select specific post types to enable selective locking\n1. Set default lock mode (Paywall or Login Only)\n1. Configure bypass roles for administrators or other user roles<\/p>\n\n<p><strong>Step 5: Customize Appearance<\/strong>\n1. Navigate to <strong>PostGate &gt; Settings &gt; Appearance<\/strong>\n1. Choose preview mode (Paragraphs or Words)\n1. Set preview limit (how much content to show before paywall)\n1. Customize paywall text, badges, and button labels\n1. Save your settings<\/p>\n\n<p><strong>Step 6: Apply to Content<\/strong>\n1. Edit any post or page\n1. In the PostGate sidebar panel, configure lock settings\n1. Select product options for the content\n1. Publish or update the post\n1. Visit the post on your site to see the paywall in action<\/p>\n\n<!--section=faq-->\n<dl>\n<dt id=\"how%20do%20i%20add%20a%20paywall%20to%20my%20wordpress%20site%3F\"><h3>How do I add a paywall to my WordPress site?<\/h3><\/dt>\n<dd><p>PostGate makes it easy to add a paywall to any WordPress site. Simply install the plugin, connect your Stripe account, and choose whether to lock your entire site, specific post types, individual posts, or even specific content blocks. You can be up and running with a WordPress paywall in under 10 minutes.<\/p><\/dd>\n<dt id=\"what%20is%20the%20best%20wordpress%20paywall%20plugin%3F\"><h3>What is the best WordPress paywall plugin?<\/h3><\/dt>\n<dd><p>PostGate is designed to be the most flexible WordPress paywall solution available. Unlike other paywall plugins that only offer site-wide locking, PostGate lets you create paywalls at the site, category, post, or block level. It supports both one-time purchases and recurring subscriptions, giving you complete control over how you monetize your WordPress content.<\/p><\/dd>\n<dt id=\"how%20much%20does%20it%20cost%20to%20add%20a%20paywall%20to%20wordpress%3F\"><h3>How much does it cost to add a paywall to WordPress?<\/h3><\/dt>\n<dd><p>PostGate is completely free to download and use from WordPress.org. There are no monthly fees, no setup costs, and no limits on how many paywalls you can create. You'll need a free Stripe account to process payments (Stripe charges standard payment processing fees, typically 2.9% + $0.30 per transaction in the US). To support ongoing development, security updates, and new features, PostGate applies a small 5% platform fee to transactions - significantly lower than most SaaS paywall solutions that charge $50-500+ per month.<\/p><\/dd>\n<dt id=\"do%20i%20need%20a%20stripe%20account%20to%20use%20postgate%3F\"><h3>Do I need a Stripe account to use PostGate?<\/h3><\/dt>\n<dd><p>Yes, PostGate requires a Stripe account to process payments. Stripe is a secure, PCI-compliant payment processor used by millions of businesses worldwide. You can create a free account at stripe.com.<\/p><\/dd>\n<dt id=\"can%20i%20test%20the%20plugin%20before%20going%20live%3F\"><h3>Can I test the plugin before going live?<\/h3><\/dt>\n<dd><p>Absolutely! PostGate supports both Stripe Sandbox (test) and Live modes. Start in Sandbox mode to test the entire payment flow without processing real payments. When you're ready, switch to Live mode in the settings.<\/p><\/dd>\n<dt id=\"how%20much%20does%20it%20cost%20to%20use%20postgate%3F\"><h3>How much does it cost to use PostGate?<\/h3><\/dt>\n<dd><p>PostGate is completely free to download and use. There are no monthly fees, no setup costs, and no limits on how many paywalls you can create.<\/p>\n\n<p>To process payments, you'll need a free Stripe account. Stripe charges standard payment processing fees (typically 2.9% + $0.30 per transaction in the US).<\/p>\n\n<p>To support ongoing development, security updates, and new features, PostGate applies a small 5% platform fee to transactions. This is significantly lower than most SaaS paywall solutions that charge $50-500+ per month. Check Stripe's pricing page for payment processing fees in your country.<\/p><\/dd>\n<dt id=\"can%20i%20gate%20only%20specific%20posts%20instead%20of%20the%20entire%20site%3F\"><h3>Can I gate only specific posts instead of the entire site?<\/h3><\/dt>\n<dd><p>Yes! PostGate offers multiple gating strategies:\n- Lock your entire site\n- Lock specific post types (posts, pages, custom post types)\n- Lock individual posts or pages\n- Lock categories or taxonomies\n- Lock specific blocks within posts<\/p><\/dd>\n<dt id=\"what%20happens%20if%20i%20change%20my%20stripe%20products%3F\"><h3>What happens if I change my Stripe products?<\/h3><\/dt>\n<dd><p>Users who already purchased access retain their access. New purchases will use the updated products. You can sync new products from Stripe at any time using the \"Fetch &amp; Sync Products\" button.<\/p><\/dd>\n<dt id=\"can%20users%20purchase%20access%20without%20creating%20an%20account%3F\"><h3>Can users purchase access without creating an account?<\/h3><\/dt>\n<dd><p>No, users must log in or create an account before purchasing. This ensures proper access management and allows users to access purchased content from any device.<\/p><\/dd>\n<dt id=\"what%20payment%20methods%20does%20postgate%20support%3F\"><h3>What payment methods does PostGate support?<\/h3><\/dt>\n<dd><p>PostGate supports all payment methods enabled in your Stripe account, including credit cards, debit cards, Apple Pay, Google Pay, and many regional payment methods.<\/p><\/dd>\n<dt id=\"can%20i%20offer%20both%20subscriptions%20and%20one-time%20purchases%3F\"><h3>Can I offer both subscriptions and one-time purchases?<\/h3><\/dt>\n<dd><p>Yes! You can mix payment models. For example, offer individual articles for one-time purchase or a subscription for unlimited access. Users see all available options and choose their preference.<\/p><\/dd>\n<dt id=\"how%20do%20i%20customize%20the%20paywall%20design%3F\"><h3>How do I customize the paywall design?<\/h3><\/dt>\n<dd><p>PostGate includes two built-in templates (Compact and Classic). For advanced customization, copy the template files from the plugin to your theme directory under <code>\/postgate\/templates\/<\/code> and modify them as needed.<\/p><\/dd>\n<dt id=\"can%20i%20preview%20content%20before%20the%20paywall%20for%20seo%3F\"><h3>Can I preview content before the paywall for SEO?<\/h3><\/dt>\n<dd><p>Yes! PostGate includes intelligent preview functionality. You can show the first N paragraphs or N words before the paywall. This allows search engines to index your content while still protecting it.<\/p><\/dd>\n<dt id=\"what%20happens%20when%20a%20subscription%20is%20canceled%3F\"><h3>What happens when a subscription is canceled?<\/h3><\/dt>\n<dd><p>When a subscription is canceled in Stripe, PostGate automatically receives a webhook notification and revokes the user's access to subscription-protected content.<\/p><\/dd>\n<dt id=\"can%20i%20refund%20purchases%3F\"><h3>Can I refund purchases?<\/h3><\/dt>\n<dd><p>Yes, process refunds through your Stripe dashboard. PostGate will receive a webhook notification and automatically revoke the user's access to the refunded content.<\/p><\/dd>\n<dt id=\"does%20postgate%20work%20with%20caching%20plugins%3F\"><h3>Does PostGate work with caching plugins?<\/h3><\/dt>\n<dd><p>Yes, but ensure that logged-in users are excluded from caching. Most caching plugins do this automatically. If you experience issues, add the paywall pages to your cache exclusion list.<\/p><\/dd>\n<dt id=\"can%20i%20grant%20access%20to%20specific%20user%20roles%20without%20payment%3F\"><h3>Can I grant access to specific user roles without payment?<\/h3><\/dt>\n<dd><p>Yes! Configure bypass roles in <strong>PostGate &gt; Settings &gt; General<\/strong>. By default, administrators bypass all paywalls. You can add any WordPress role to the bypass list.<\/p><\/dd>\n<dt id=\"does%20postgate%20support%20multiple%20currencies%3F\"><h3>Does PostGate support multiple currencies?<\/h3><\/dt>\n<dd><p>Yes! PostGate supports all currencies available in Stripe. Set your preferred display currency in the settings, and users will see prices in that currency.<\/p><\/dd>\n<dt id=\"can%20i%20lock%20custom%20post%20types%3F\"><h3>Can I lock custom post types?<\/h3><\/dt>\n<dd><p>Absolutely! Enable any custom post type in <strong>PostGate &gt; Settings &gt; General<\/strong> under \"Enabled Post Types\". PostGate works with any public post type.<\/p><\/dd>\n<dt id=\"what%20if%20users%20share%20their%20login%20credentials%3F\"><h3>What if users share their login credentials?<\/h3><\/dt>\n<dd><p>While PostGate doesn't prevent password sharing, you can limit this by: (1) monitoring for unusual login patterns, (2) implementing two-factor authentication with a separate plugin, or (3) using device limits if you extend the plugin.<\/p><\/dd>\n<dt id=\"is%20postgate%20compatible%20with%20page%20builders%3F\"><h3>Is PostGate compatible with page builders?<\/h3><\/dt>\n<dd><p>Yes! PostGate works with any page builder including Elementor, Divi, Beaver Builder, and others. The paywall applies at the content filter level, so it works regardless of how the content was created.<\/p><\/dd>\n<dt id=\"can%20i%20track%20revenue%20and%20conversions%3F\"><h3>Can I track revenue and conversions?<\/h3><\/dt>\n<dd><p>PostGate includes a dashboard with order management and basic revenue tracking. For detailed analytics, use your Stripe dashboard which provides comprehensive reporting and analytics.<\/p><\/dd>\n<dt id=\"what%20happens%20during%20plugin%20updates%3F\"><h3>What happens during plugin updates?<\/h3><\/dt>\n<dd><p>Your settings, products, and user access grants are stored in the WordPress database and remain intact during updates. Always backup your database before updating any plugin.<\/p><\/dd>\n<dt id=\"does%20postgate%20slow%20down%20my%20site%3F\"><h3>Does PostGate slow down my site?<\/h3><\/dt>\n<dd><p>PostGate is optimized for performance. Assets only load on pages with protected content. The access check is a simple database query that adds minimal overhead.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.0.3<\/h4>\n\n<ul>\n<li>Fixed: Removed composer from deployment pipeline to use committed vendor directory<\/li>\n<li>Fixed: Simplified deployment by using local vendor\/ instead of building with composer<\/li>\n<li>Improved: Updated build:all script to skip composer install (vendor already tracked)<\/li>\n<li>Improved: Streamlined GitHub Actions workflow to reduce deployment time<\/li>\n<\/ul>\n\n<h4>1.0.2<\/h4>\n\n<ul>\n<li>Fixed: Ensured complete Stripe SDK deployment via improved .gitattributes configuration<\/li>\n<li>Fixed: Resolved issue where vendor files were excluded from WordPress.org deployment<\/li>\n<li>Improved: Added negation patterns in .gitattributes to force inclusion of vendor\/stripe directory<\/li>\n<li>Improved: GitHub Actions workflow now uses optimized Composer installation flags<\/li>\n<\/ul>\n\n<h4>1.0.1<\/h4>\n\n<ul>\n<li>Fixed: Stripe SDK autoloader not properly included in WordPress.org deployment<\/li>\n<li>Fixed: GitHub Actions workflow to ensure all Composer dependencies are properly installed<\/li>\n<li>Improved: Added verification checks in GitHub Actions to validate Stripe SDK files before deployment<\/li>\n<li>Improved: Enhanced error reporting for deployment workflow<\/li>\n<\/ul>","raw_excerpt":"Complete WordPress paywall solution. Create flexible paywalls, sell content with purchases or subscriptions, and monetize via Stripe.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/280789","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=280789"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/qodesphere"}],"wp:attachment":[{"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=280789"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=280789"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=280789"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=280789"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=280789"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=280789"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}