-
Notifications
You must be signed in to change notification settings - Fork 0
/
bibcite.php
114 lines (100 loc) · 3.2 KB
/
bibcite.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
<?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 activation,
* deactivation and uninstallation functions, and defines a function that starts the plugin.
*
* @link https://github.com/ShadyChars/Bibcite
* @since 1.0.0
* @package Bibcite
*
* @wordpress-plugin
* Plugin Name: Bibcite-CSL
* Plugin URI: https://github.com/ShadyChars/Bibcite
* Description: A simple CSL JSON parser and citation generator for WordPress.
* Version: 2.0.0
* Author: Keith Houston
* Author URI: https://github.com/ShadyChars/
* License: GPL-2.0+
* License URI: http://www.gnu.org/licenses/gpl-2.0.txt
* Text Domain: bibcite
* Domain Path: /languages
*/
if (!defined('WPINC')) {
die;
}
require plugin_dir_path(__FILE__) . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Current plugin version.
*/
define('BIBCITE_VERSION', '2.0.0');
/**
* A general prefix used to scope databases, tables, constants, and so on.
*/
define('BIBCITE_PREFIX', 'BIBCITE');
/**
* Directory used to cache downloaded files and compiles templates, relative to
* the main plugin directory.
*/
define('BIBCITE_CACHE_DIRECTORY', 'cache');
/**
* Define a custom hook fired when the plugin is reset to a factory state.
*/
define('BIBCITE_CLEAR_CACHE_ACTION', BIBCITE_PREFIX . "_CLEAR_CACHE");
/**
* The code that runs during plugin activation.
*/
function activate_bibcite()
{
Bibcite\Common\Logger::instance()->info("Activating plugin...");
Bibcite\Common\Activator::activate();
Bibcite\Common\Logger::instance()->info("Activated plugin.");
}
/**
* The code that runs during plugin deactivation.
*/
function deactivate_bibcite()
{
Bibcite\Common\Logger::instance()->info("Deactivating plugin...");
Bibcite\Common\Deactivator::deactivate();
Bibcite\Common\Logger::instance()->info("Deactivated plugin.");
}
/**
* The code that runs during our custom BIBCITE_CLEAR_CACHE_ACTION.
*/
function clear_cache_bibcite()
{
Bibcite\Common\Logger::instance()->info("Clearing cached data...");
Bibcite\Common\CacheClearer::clear_cache();
Bibcite\Common\Logger::instance()->info("Cleared cached data.");
}
/**
* The code that runs during plugin uninstallation.
*/
function uninstall_bibcite()
{
Bibcite\Common\Logger::instance()->info("Uninstalling plugin...");
Bibcite\Common\Uninstaller::uninstall();
Bibcite\Common\Logger::instance()->info("Uninstalled plugin.");
}
/**
* 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_bibcite()
{
register_activation_hook(__FILE__, 'activate_bibcite');
register_deactivation_hook(__FILE__, 'deactivate_bibcite');
register_uninstall_hook(__FILE__, 'uninstall_bibcite');
add_action(BIBCITE_CLEAR_CACHE_ACTION, 'clear_cache_bibcite');
$plugin = new Bibcite\Common\Bibcite();
$plugin->run();
}
run_bibcite();