-
Notifications
You must be signed in to change notification settings - Fork 1
/
qi-gateway.php
126 lines (109 loc) · 3.51 KB
/
qi-gateway.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<?php
/**
* The plugin bootstrap file
*
* This file is read by WordPress to generate the plugin information in the plugin
* admin area. This file also includes all of the dependencies used by the plugin,
* registers the activation and deactivation functions, and defines a function
* that starts the plugin.
*
* @link https://mahmoodshakir.com/
* @since 1.0.0
* @package Qi_Gateway
*
* @wordpress-plugin
* Plugin Name: Qi Gateway: UnOfficial Advanced Gateway Integration
* Plugin URI: https://qi.mahmoodshaki.com/
* Description: Add Qi Card as payment method for Wordpress easily.
* Version: 1.3.1
* Author: Mahmood A.Shakir
* Author URI: https://mahmoodshaki.com/
* License: GPL-2.0+
* License URI: http://www.gnu.org/licenses/gpl-2.0.txt
* Text Domain: qi-gateway
* Domain Path: /languages
*/
// If this file is called directly, abort.
if (!defined('WPINC')) {
die;
}
require_once "enums/qi-gateway-enums.php";
/**
* Currently plugin version.
* Start at version 1.0.0 and use SemVer - https://semver.org
* Rename this for your plugin and update it as you release new versions.
*/
define('QI_GATEWAY_VERSION', '1.3.1');
/**
* Api URL
*/
define('API_DOMAIN', 'https://api.pay.qi.iq/api/v0');
/**
* The code that runs during plugin activation.
* This action is documented in includes/class-qi-gateway-activator.php
*/
function activate_qi_gateway()
{
require_once plugin_dir_path(__FILE__) . 'includes/class-qi-gateway-activator.php';
Qi_Gateway_Activator::activate();
}
/**
* The code that runs during plugin deactivation.
* This action is documented in includes/class-qi-gateway-deactivator.php
*/
function deactivate_qi_gateway()
{
require_once plugin_dir_path(__FILE__) . 'includes/class-qi-gateway-deactivator.php';
Qi_Gateway_Deactivator::deactivate();
}
register_activation_hook(__FILE__, 'activate_qi_gateway');
register_deactivation_hook(__FILE__, 'deactivate_qi_gateway');
/**
* The core plugin class that is used to define internationalization,
* admin-specific hooks, and public-facing site hooks.
*/
require plugin_dir_path(__FILE__) . 'includes/class-qi-gateway.php';
/**
* Update checker for plugin
*
* @since 1.0.0
*/
if (is_admin()) {
if (!class_exists('Puc_v4_Factory')) {
require_once plugin_dir_path(__FILE__) . 'includes/libraries/plugin-update-checker-4.9/plugin-update-checker.php';
$myUpdateChecker = Puc_v4_Factory::buildUpdateChecker(
'https://plugins.mahmoodshakir.com/qi.json',
__FILE__, //Full path to the main plugin file or functions.php.
'qi-gateway'
);
}
if(!class_exists('Qi_Gateway_Disclaimer')) {
require_once "includes/class-qi-gateway-disclaimer.php";
Qi_Gateway_Disclaimer::init();
}
}
/**
* Begins execution of the plugin.
*
* Since everything within the plugin is registered via hooks,
* then kicking off the plugin from this point in the file does
* not affect the page life cycle.
*
* @since 1.0.0
*/
function run_qi_gateway()
{
if (class_exists('WC_Payment_Gateway')) {
$plugin = new Qi_Gateway();
$plugin->run();
} else {
add_action('admin_notices', function () {
?>
<div class="error notice">
<p><?php echo __('Sorry, you need to install Woocommerce plugin to use Qi Gateway') ?></p>
</div>
<?php
});
}
}
add_filter('plugins_loaded', 'run_qi_gateway');