-
-
Notifications
You must be signed in to change notification settings - Fork 161
/
jwt-auth.php
executable file
·93 lines (82 loc) · 2.43 KB
/
jwt-auth.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
<?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 the dependencies used by the plugin,
* registers the activation and deactivation functions, and defines a function
* that starts the plugin.
*
* @link https://enriquechavez.co
* @since 1.0.0
*
* @wordpress-plugin
* Plugin Name: JWT Authentication for WP-API
* Plugin URI: https://enriquechavez.co
* Description: Extends the WP REST API using JSON Web Tokens Authentication as an authentication method.
* Version: 1.3.4
* Author: Enrique Chavez
* Author URI: https://enriquechavez.co
* License: GPL-2.0+
* License URI: http://www.gnu.org/licenses/gpl-2.0.txt
* Text Domain: jwt-auth
* Domain Path: /languages
*/
// If this file is called directly, abort.
if ( ! defined( 'WPINC' ) ) {
die;
}
/**
* 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-jwt-auth.php';
/**
* The CRON functionality of the plugin.
*
* If the user agrees to share data, then we will send some data to the author of the plugin
* to keep track opf the number of installations, the WP version and the PHP version used.
*/
require plugin_dir_path( __FILE__ ) . 'admin/class-jwt-auth-cron.php';
/**
* Schedule an action if it's not already scheduled
*/
if ( ! wp_next_scheduled( 'jwt_auth_share_data' ) ) {
wp_schedule_event( time(), 'weekly', 'jwt_auth_share_data' );
}
/**
* Run the action that'll fire every week
*
* @return void
*/
function jwt_auth_share_data() {
Jwt_Auth_Cron::collect();
}
/**
* Hook into the action that'll fire every week
*/
add_action( 'jwt_auth_share_data', 'jwt_auth_share_data' );
/**
* This runs during plugin deactivation.
*/
function deactivate_jwt_auth() {
Jwt_Auth_Cron::remove();
}
/**
* Hook into the action that'll fire during plugin deactivation
*/
register_deactivation_hook( __FILE__, 'deactivate_jwt_auth' );
/**
* 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_jwt_auth() {
$plugin = new Jwt_Auth();
$plugin->run();
}
run_jwt_auth();