by Vishavjeet | Nov 13, 2024 | blog, WordPress
Creating a Custom WooCommerce Payment Gateway Plugin
Creating a WooCommerce Payment Gateway Plugin allows developers to integrate custom payment options into WooCommerce, the popular e-commerce platform for WordPress. While WooCommerce supports various payment methods out of the box, there may be times when you need to add a payment gateway not natively supported by WooCommerce, such as a regional payment processor or a unique custom payment method.
A custom WooCommerce Payment Gateway Plugin provides flexibility by letting store owners offer payment options tailored to specific customer needs or geographical areas. By following WordPress and WooCommerce’s coding standards, developers can create secure, user-friendly, and highly functional payment gateways that integrate seamlessly into WooCommerce’s checkout process. This guide walks through the process, covering essential concepts like setting up the plugin, configuring the gateway settings, handling payments, and adding frontend customizations.
Prerequisites:
- Basic knowledge of PHP, HTML, and WooCommerce.
- Access to a WooCommerce development environment (localhost or staging).
- Familiarity with WordPress plugins and WooCommerce.
Folder Structure for the WooCommerce Payment Gateway Plugin
Explanation of Each File
- worldwin-coder-payment-gateway.php
- The main plugin file that initializes the payment gateway plugin. It contains the plugin header and setup code.
- includes/class-wc-gateway-worldwin.php
- Contains the main payment gateway class (
WC_Gateway_WorldWin
) where the custom gateway functionality is defined, including settings, form fields, and the payment processing logic.
- assets/css/style.css (Optional)
- Custom styles for the plugin (e.g., styling for custom checkout fields). This file is optional unless you need additional CSS.
- assets/js/script.js (Optional)
- Custom JavaScript for the plugin. Use this file for any JavaScript that enhances checkout functionality, if required.
- languages/worldwin-coder-payment-gateway.pot (Optional)
- A
.pot
file for translation. This is optional but recommended if you want the plugin to support multiple languages.
- README.txt (Optional)
- A README file that provides plugin description, setup instructions, and any special notes. This file is especially helpful for sharing or distributing the plugin.
Creating a Custom WooCommerce Payment Gateway Plugin
Step 1: Setup Plugin Directory and Files
- Navigate to your WordPress installation directory: Go to
wp-content/plugins/
and create a folder named worldwin-coder-payment-gateway
.
- Create the main plugin file: Inside the folder, create a file named
worldwin-coder-payment-gateway.php
. This file will be the main plugin file.
- Add Plugin Header: Open
worldwin-coder-payment-gateway.php
and add the plugin header information:
<?php
/*
Plugin Name: WorldWin Coder Custom Payment Gateway
Plugin URI: https://example.com
Description: Custom Payment Gateway for WooCommerce
Version: 1.0
Author: Your Name
Author URI: https://example.com
*/
Step 2: Initialize the Payment Gateway Class
- Hook to initialize the gateway: Add the following code to hook your gateway initialization:
if (!defined('ABSPATH')) exit; // Exit if accessed directly
add_action('plugins_loaded', 'worldwin_coder_init', 0);
function worldwin_coder_init() {
if (!class_exists('WC_Payment_Gateway')) return;
include_once 'includes/class-wc-gateway-worldwin.php';
add_filter('woocommerce_payment_gateways', 'add_worldwin_coder_gateway');
}
function add_worldwin_coder_gateway($methods) {
$methods[] = 'WC_Gateway_WorldWin';
return $methods;
}
- Create the payment gateway class file: Inside your plugin folder, create a new folder named
includes
. Inside the includes
folder, create a file named class-wc-gateway-worldwin.php
.
Step 3: Build the Payment Gateway Class
- Define your custom payment gateway: Open
class-wc-gateway-worldwin.php
and add the following code:
-
<?php
class WC_Gateway_WorldWin extends WC_Payment_Gateway {
public function __construct() {
$this->id = 'worldwin';
$this->icon = ''; // URL of the icon
$this->has_fields = true;
$this->method_title = 'WorldWin Coder Gateway';
$this->method_description = 'Custom Payment Gateway for WooCommerce';
// Load the settings
$this->init_form_fields();
$this->init_settings();
// Define user settings variables
$this->title = $this->get_option('title');
$this->description = $this->get_option('description');
$this->instructions = $this->get_option('instructions');
// Save admin options
add_action('woocommerce_update_options_payment_gateways_' . $this->id, [$this, 'process_admin_options']);
}
public function init_form_fields() {
$this->form_fields = [
'enabled' => [
'title' => 'Enable/Disable',
'type' => 'checkbox',
'label' => 'Enable WorldWin Payment Gateway',
'default' => 'yes'
],
'title' => [
'title' => 'Title',
'type' => 'text',
'description' => 'This controls the title shown during checkout.',
'default' => 'WorldWin Payment',
'desc_tip' => true,
],
'description' => [
'title' => 'Description',
'type' => 'textarea',
'description' => 'This controls the description shown during checkout.',
'default' => 'Pay securely with WorldWin.',
],
'instructions' => [
'title' => 'Instructions',
'type' => 'textarea',
'description' => 'Instructions for the customer after order completion.',
'default' => 'Thank you for using WorldWin Payment.',
]
];
}
}
Step 4: Add Payment Processing Logic
- Add payment process method: Inside the class, add a function to handle the payment processing. Modify it to fit the specifics of your payment gateway API:
public function process_payment($order_id) {
global $woocommerce;
$order = wc_get_order($order_id);
// Mark order as processing (can also use 'completed')
$order->update_status('processing', 'Order processed with WorldWin Gateway.');
// Reduce stock levels
wc_reduce_stock_levels($order_id);
// Clear cart
$woocommerce->cart->empty_cart();
// Redirect to order confirmation page
return [
'result' => 'success',
'redirect' => $this->get_return_url($order)
];
}
- Add custom checkout fields (optional): If you need custom fields on the checkout page, define them in
payment_fields
:
public function payment_fields() {
echo '<p>' . esc_html($this->description) . '</p>';
}
Step 5: Final Testing and Debugging
- Activate the plugin: Go to your WordPress dashboard, navigate to “Plugins,” and activate “WorldWin Coder Custom Payment Gateway.”
- Test the gateway:
- Go to WooCommerce settings, click on “Payments,” and enable the WorldWin Coder gateway.
- Try a test checkout to ensure it processes as expected.
- Debugging and Logging (optional): Add logging features if you need to troubleshoot errors. WooCommerce provides a logger:
$this->log = new WC_Logger();
$this->log->add('worldwin', 'Logging message here...');
Step 6: Finalizing and Packaging
- Document any setup instructions for users and package the plugin files into a
.zip
for distribution.
With this setup, you have a functional custom WooCommerce payment gateway plugin. Modify the process_payment
method to connect with any specific payment API your gateway requires.
Happy coding!
What’s your Biggest WooCommerce Challenge Right Now?
Let’s Talk
by Vishavjeet | Nov 7, 2024 | blog
PHP Version History: Key Features & Enhancements from PHP 5 to PHP 8.3
PHP has undergone significant evolution, bringing new features, performance improvements, and security updates with each version. Here’s a look at the most impactful updates from PHP 5 onwards to help you understand what each version offers.
PHP 5.x (2004 – 2014): Laying the Foundation for Modern PHP
- PHP 5.0 (2004)
- Introduction of Object-Oriented Programming (OOP): PHP 5 introduced a robust OOP model, supporting classes, inheritance, encapsulation, and polymorphism, which helped PHP become more versatile.
- PDO (PHP Data Objects): PDO provided a unified database access interface, supporting prepared statements, which enhanced security and made SQL injection harder.
- Improved Error Handling: Exceptions were introduced, enabling developers to write more reliable code by handling errors gracefully.
- PHP 5.3 (2009)
- Namespaces: This addition allowed better code organization by grouping related classes, functions, and constants.
- Anonymous Functions & Closures: PHP 5.3 introduced anonymous functions and closures, allowing developers to write more concise and functional code.
- Late Static Binding: This feature improved inheritance by allowing static references to the called class.
- PHP 5.4 (2012)
- Short Array Syntax: The new
[ ]
syntax replaced the old array()
for cleaner and shorter code.
- Traits: PHP 5.4 introduced traits, allowing code reuse across classes without traditional inheritance, which improved flexibility in OOP.
- Built-in Web Server: A basic web server was introduced for testing purposes, making local development more accessible.
- PHP 5.5 (2013)
- Generators: This new feature allowed developers to create iterators more efficiently using the
yield
keyword.
finally
Keyword: Adding to try-catch, finally
was introduced for code that should execute regardless of exceptions.
- Password Hashing API: A simple and secure password hashing function was introduced for better security.
PHP 7.x (2015 – 2020): Performance Boost and Modernization
- PHP 7.0 (2015)
- Significant Performance Boost: With PHP 7, the Zend Engine 3.0 doubled performance, leading to faster page loads.
- Scalar Type Declarations: Type declarations for parameters (like
int
, float
, string
, and bool
) were introduced for stricter typing.
- Return Type Declarations: This version allowed defining the return type for functions, enhancing code readability.
- Null Coalescing Operator (
??
): This new operator simplified conditional expressions by providing a concise syntax to check for null
.
- PHP 7.1 (2016)
- Nullable Types: PHP 7.1 allowed types to be nullable by prefixing them with
?
, meaning a parameter or return type could accept a specified type or null
.
- Void Return Type: This version introduced
void
as a return type, making code clearer by specifying functions that don’t return values.
- Multi-catch Exception Handling: PHP 7.1 enabled multiple exceptions to be caught in a single block, improving error handling efficiency.
- PHP 7.2 (2017)
- Argon2 Password Hashing: PHP 7.2 added support for Argon2, a modern and secure hashing algorithm for better password security.
- Object Type Hinting: Developers could now use
object
as a type hint for function arguments.
- Deprecated
each()
Function: The each()
function was deprecated, favoring more performant array handling functions.
- PHP 7.3 (2018)
- Flexible Heredoc and Nowdoc Syntax: PHP 7.3 made these syntaxes easier to use, enhancing readability in multi-line strings.
- Array Destructuring with List: The list syntax was enhanced, allowing array keys in list assignments.
- JSON_THROW_ON_ERROR: This option threw exceptions when JSON errors occurred, improving error handling when working with JSON.
- PHP 7.4 (2019)
- Typed Properties: PHP 7.4 allowed properties in classes to have types, bringing it closer to strongly typed languages.
- Arrow Functions: Shortened syntax for functions using
fn
was introduced, making inline functions more concise.
- Preloading: With preloading, commonly used PHP files could be loaded into memory, significantly boosting performance.
PHP 8.x (2020 – Present): New Syntax and JIT Compilation
- PHP 8.0 (2020)
- Just-In-Time (JIT) Compilation: This feature improved performance for CPU-intensive tasks, opening possibilities for PHP in non-web applications.
- Union Types: PHP 8.0 introduced union types, allowing parameters to accept multiple types.
- Named Arguments: Functions could now be called with named parameters, making code more readable and arguments more flexible.
- Match Expression: Similar to
switch
, but more concise and flexible.
- Attributes: Native support for metadata annotations was introduced, allowing custom attributes on code elements.
- PHP 8.1 (2021)
- Enums: PHP 8.1 added native support for enumerations, improving type safety.
- Fibers: Fibers introduced a way to handle asynchronous code, supporting concurrency within PHP applications.
- Intersection Types: Building on union types, intersection types required variables to satisfy multiple types.
- Readonly Properties: Read-only properties allowed immutable data within classes, reducing accidental modifications.
- PHP 8.2 (2022)
- Readonly Classes: Entire classes could now be designated as
readonly
, ensuring all properties within the class were immutable.
- Disjunctive Normal Form Types (DNF Types): This new typing system allowed for more complex type declarations.
- Deprecated Dynamic Properties: PHP 8.2 deprecated dynamic properties, encouraging developers to predefine all properties, improving code quality.
- PHP 8.3 (2023)
- json_validate() Function: This function allowed JSON strings to be validated without decoding them, improving JSON handling.
- Improved
readonly
Properties: Enhanced support for readonly
properties helped enforce immutability across classes.
- Enhanced Performance and Bug Fixes: PHP 8.3 included additional optimizations and stability improvements.
Conclusion
The journey from PHP 5 to PHP 8.3 has been transformative, with major leaps in performance, security, and functionality. PHP has continually adapted to meet the needs of modern developers, providing tools that allow for writing faster, safer, and more maintainable code. As PHP continues to evolve, staying updated with each version ensures you’re making the most of its capabilities.
by Vishavjeet | Jan 11, 2024 | blog, Uncategorized
In 2024 you need to be prepared for converting your ideas and dreams into a reality. You may not have the power, but you can make it happen. Similarly, if you have been thinking about how you can put your creative writing ideas on paper or in a digital format, hire ghostwriters.
They are qualified and certified services working on the project of knitting best stories. If you are a business person short on time and need to convey some words of wisdom, ghostwriting services are here to help you especially if you are from the USA.
With so many digital conveniences and profound services available online ghostwriting services are one of them. So, buckle up! And get to know about some top names for ghostwriting services in the USA. These services are not only working for or in the USA, but are available for services worldwide.
List of Top 10 Ghostwriting Services in the USA for 2024
Vox Ghostwriting is known as a premier ghostwriting service that is looking to deliver custom content to various genres. The professional team of Vox is trained and exhibits their talent and expertise by crafting ingenious writeups.
They make sure to understand the narrative that resonates with the client’s vision. Whether you need help in fiction or non-fiction, business writing, or academic projects.
Vox Ghostwriting tailors its services to meet specific needs. With a focus on quality and confidentiality, they navigate the intricacies of each project, providing a seamless and collaborative experience.
Vox Ghostwriting’s dedication to working on its vision shows it is a reliable partner for individuals and businesses seeking expertly crafted, bespoke written content.
Ghostwriting Solution offers a comprehensive suite of writing services tailored to individual and business needs. Their expert ghostwriters ensure the delivery of high-quality, personalized content while maintaining the highest confidentiality throughout the project.
Ghostwriting Solution is your go-to for comprehensive and tailored writing services. The experts of Ghostwriting Solution expert ghostwriters deliver high-quality content while ensuring confidentiality. Whether it’s a personal memoir or a business project, they will help bring ideas to life.
The writers and editors can be trusted for a flawless experience, crafting customized solutions that resonate with your unique vision and writing demands.
Ghostwriter Inside
Ghostwriter Inside boasts a team of seasoned professionals who provide personalized and confidential ghostwriting services. Their ghostwriting service is designed with a number of writing styles in different genres so if you are thinking where to go, now you know.
Their expertise spans diverse genres, ensuring a creative and client-centric approach to every project.
The entire team is professional and seasoned with talent that manifests and puts everything in the right words. Businesses and individuals can also get optimum editing as well as publishing services.
They give a chance to every story and listen to every idea of their client. Ghostwriting Inside is internationally recognized and also provides world-class solutions and meet each demand of their client.
Nexus Ghostwriting
Nexus Ghostwriting stands at the forefront of online ghostwriting services offering unparalleled industry-specific writeups. With a team of knowledgeable writers and editors, Nexus Ghostwriting ensures the delivery of comprehensive and compelling content.
The content is designed to meet the unique needs of a diverse clientele. Whether it is a memoir, business manuscript, or content for the economic market their expertise shines through.
Nexus Ghostwriting goes beyond traditional writing services, providing clients with immaculate experience and content that not only meets but exceeds industry standards.
Fiction Ghostwriting
Fiction Ghostwriting emerges as a top name for ghostwriting services specializing in the art of storytelling. They have a polished team of creative minds, they craft life into narratives, capturing the perspective of authors’ dreams, ideas, and voices.
Whether it’s novels, short stories, or creative manuscripts, Fiction Ghostwriting crafts compelling stories that resonate with readers. It won’t be wrong to say that the world of Ficion Ghostwriting is one of the best solutions for writing books, magazines, or articles.
Ghostwriting Saga
Ghostwriting Saga is known for writing a perfect narrative for content creation, proofreading, formatting, audiobooks, and more. With a comprehensive suite of writing solutions, the saga unfolds as they deftly navigate diverse genres and industries. Beyond crafting compelling content.
Ghostwriting Saga excels in efficient project management, ensuring timelines are met without compromising the quality of the project. What sets them apart from others is their grip on their work and the fulfillment of their commitment.
The clients experience a transparent journey, looking at their ideas converting into solid books and written content.
Collins Ghostwriting
At Collins Ghostwriting, it’s not just about words; it’s about making dreams come true. They are not a typical writing service, but an inclusive ghostwriting service fulfilling all the needs. The team is experienced and passionate and is here to make your ideas shine. They promote collaboration, putting your vision front and center.
Whether it’s a memoir, a business project, or a fictional write-up. The teams dig deep to understand your voice and bring it authentically to the page. At Collins, Ghostwriting is not just about delivering content but putting everything in the right place.
Cloud Ghostwriting
Cloud Ghostwriting is another ultimate addition to your writing services. With perfection and a transparent approach, they work their way into writing and editing. Your project takes flight in a virtual land where ideas are integrated into words. Whether you’re in need of blog posts, articles, or innovative content, Cloud Ghostwriting services are here at your service.
Barnett Ghostwriting
Barnett Ghostwriting stands out for its experienced team dedicated to surpassing client expectations. Their phenomenal detail and commitment to excellence make them a reliable choice for ghostwriting services for businesses and individuals. Contact them for any kind of books or stories and get them delivered on time.
Ghostwriting Mania
Begin on a writing adventure with Ghostwriting Mania as they are not just storytellers but work on dreams. They have hired a diverse team geared up to turn your ideas into excellent readable content.
At Ghostwriting Mania, your story takes center stage. With them it’s not just about writing; it’s about crafting magic with words. Join Ghostwriting Mania, where creative minds will meet and add up a notch to your ideas converting them into a flawless piece of writing.
by Vishavjeet | Jan 8, 2024 | blog, WordPress
In the rapidly evolving world of online education, selecting the right Learning Management System (LMS) is crucial for both educators and learners. Two popular options that often find themselves in the spotlight are LearnPress vs LearnDash. In this article, we’ll delve into the features, advantages, and considerations for both platforms to help you make an informed decision based on your specific needs.
LearnPress Overview:
LearnPress is a WordPress LMS plugin that seamlessly integrates with your existing WordPress website. Known for its user-friendly interface and cost-effectiveness, LearnPress is an excellent choice for those looking to create and manage courses without a steep learning curve.
Key Features of LearnPress:
- Ease of Use: LearnPress is designed with simplicity in mind. Its intuitive interface allows even beginners to create, manage, and sell courses effortlessly.
- Flexibility: The plugin is highly customizable, allowing you to tailor the appearance and functionality of your courses. You can choose from various add-ons and themes to enhance the learning experience.
- Affordability: LearnPress is budget-friendly, making it an ideal choice for small businesses, individual instructors, or anyone operating on a limited budget.
LearnDash Overview:
LearnDash, on the other hand, is a robust LMS solution that offers advanced features and is suitable for a wide range of users, from individual educators to large enterprises. Unlike LearnPress, LearnDash is a standalone LMS and doesn’t rely on WordPress.
Key Features of LearnDash:
- Advanced Course Builder: LearnDash provides a powerful course builder with intricate options for organizing and structuring course content. This is particularly beneficial for complex and comprehensive courses.
- Engagement Features: LearnDash offers features such as quizzes, assignments, and certificates to enhance learner engagement. Gamification elements are also available to make the learning experience more interactive.
- Membership and Subscription: LearnDash supports membership and subscription models, enabling you to monetize your courses effectively. This is advantageous for businesses looking to create a recurring revenue stream.
Considerations for Your Decision:
- Budget: If you’re operating on a tight budget, LearnPress may be the more economical choice. However, if you have the financial means and are looking for advanced features, LearnDash might be worth the investment.
- Ease of Use vs. Advanced Functionality: Consider your technical expertise and the complexity of your courses. LearnPress is user-friendly, while LearnDash offers a more sophisticated set of features.
- Scalability: If you plan on expanding your courses and catering to a larger audience, LearnDash’s scalability may better suit your long-term goals.
Conclusion:
Ultimately, the choice between LearnPress vs LearnDash depends on your specific needs, budget, and technical requirements. Both platforms have their strengths, so carefully evaluate your priorities and preferences before making a decision. Whether you opt for the simplicity of LearnPress or the advanced features of LearnDash, investing time in choosing the right LMS is an investment in the success of your online education endeavors.
by Vishavjeet | Jan 5, 2024 | blog, WordPress
In the dynamic world of e-commerce, selecting the right payment gateway is a critical decision for online store owners. Two popular choices, WooCommerce Payments and Stripe, stand out for their robust features and ease of integration. In this article, we’ll compare WooCommerce Payments vs Stripe, shedding light on their key features, advantages, and considerations to help you make an informed decision for your online business.
Understanding WooCommerce Payments:
1. Seamless Integration: WooCommerce Payments is a payment gateway developed by the creators of WooCommerce itself. This integration ensures seamless compatibility and easy setup for merchants already using the WooCommerce platform.
2. Unified Dashboard: One of the standout features of WooCommerce Payments is its unified dashboard within the WooCommerce admin. This streamlines the management of both your products and payments in a single interface, providing a cohesive experience for store owners.
3. Competitive Transaction Fees: WooCommerce Payments offers competitive transaction fees. The transparent fee structure makes it easier for businesses to calculate their costs and manage their finances effectively.
Exploring Stripe:
1. Versatility and Global Reach: Stripe is renowned for its global reach and versatility. It supports a wide range of payment methods, including credit cards, digital wallets, and local payment options, making it an ideal choice for businesses with an international customer base.
2. Developer-Friendly API: For businesses with specific customization needs, Stripe’s developer-friendly API is a significant advantage. It provides developers with the flexibility to tailor the payment process to meet unique requirements.
3. Extensive Security Measures: Security is a top priority for Stripe. The platform employs advanced security measures, including PCI compliance and two-factor authentication, to protect both merchants and customers from potential cyber threats.
Key Considerations:
1. Integration Complexity: WooCommerce Payments offers a straightforward integration for merchants already using the WooCommerce platform. On the other hand, Stripe, while versatile, may require a bit more technical expertise for seamless integration.
2. Global Business Considerations: If your business has a global presence and caters to a diverse audience, Stripe’s extensive range of supported payment methods and currencies might be more appealing.
3. Cost Structure: When comparing the cost structure, consider not only transaction fees but also any additional fees or features that may impact your overall expenses.
Conclusion:
Choosing between WooCommerce Payments vs Stripe depends on your specific business needs, technical capabilities, and global reach. For a seamless experience within the WooCommerce ecosystem, WooCommerce Payments is an excellent choice. However, if you prioritize versatility, global accessibility, and developer customization, Stripe might be the better fit. Evaluate your priorities, test functionalities, and make an informed decision to optimize your online store’s payment process.