-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathxpress-mvc.php
148 lines (133 loc) · 4.29 KB
/
xpress-mvc.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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
<?php
/**
* Plugin Name: XPress MVC
* Version: 0.1.0
* Plugin URI: https://github.com/xpress-framework/xpress-mvc
* Description: Implements a MVC-like platform in a WordPress site.
* Author: XPress Framework
* Author URI: https://github.com/xpress-framework
* Requires at least: 4.8
* Tested up to: 4.8.1
* License: GPLv2
* License URI: http://www.gnu.org/licenses/gpl-2.0.html
*
* Text Domain: xpress-mvc
* Domain Path: /lang/
*
* @package XPress
* @subpackage MVC
*/
// Require necessary classes.
require_once 'classes/class-xpress-mvc-no-route.php';
require_once 'classes/class-xpress-mvc-request.php';
require_once 'classes/class-xpress-mvc-response.php';
require_once 'classes/class-xpress-mvc-server.php';
require_once 'classes/class-xpress-mvc-controller.php';
require_once 'classes/interface-xpress-model-crud.php';
require_once 'classes/class-xpress-mvc-model.php';
require_once 'classes/exception-xpress-invalid-model-attribute.php';
// Hook to parse_request to handle the MVC requests.
add_action( 'parse_request', 'xpress_mvc_loaded' );
/**
* Loads the XPress MVC.
*
* @since 0.1.0
*/
function xpress_mvc_loaded() {
// Initialize the server.
$server = xpress_mvc_get_server();
// Fire off the request.
$server->serve_request();
}
/**
* Retrieves the current XPress MVC server instance.
*
* Instantiates a new instance if none exists already.
*
* @since 0.1.0
*
* @global XPress_MVC_Server $xpress_mvc_server XPress MVC server instance.
*
* @return XPress_MVC_Server XPress MVC server instance.
*/
function xpress_mvc_get_server() {
/* @var WP_REST_Server $wp_rest_server */
global $xpress_mvc_server;
if ( empty( $xpress_mvc_server ) ) {
$xpress_mvc_server = new XPress_MVC_Server;
/**
* Fires when preparing to serve an API request.
*
* Endpoint objects should be created and register their hooks on this action rather
* than another action to ensure they're only loaded when needed.
*
* @since 0.1.0
*
* @param XPress_MVC_Server $wp_rest_server Server object.
*/
do_action( 'xpress_mvc_init', $xpress_mvc_server );
}
return $xpress_mvc_server;
}
/**
* Ensures a REST response is a response object (for consistency).
*
* This implements WP_HTTP_Response, allowing usage of `set_status`/`header`/etc
* without needing to double-check the object. Will also allow WP_Error to indicate error
* responses, so users should immediately check for this value.
*
* @since 0.1.0
*
* @param WP_Error|WP_HTTP_Response|mixed $response Response to check.
* @return XPress_MVC_Response|mixed If response generated an error, WP_Error, if response
* is already an instance, WP_HTTP_Response, otherwise
* returns a new XPress_MVC_Response instance.
*/
function xpress_mvc_ensure_response( $response ) {
if ( is_wp_error( $response ) ) {
return $response;
}
if ( $response instanceof XPress_MVC_Response ) {
return $response;
}
if ( $response instanceof WP_HTTP_Response ) {
return XPress_MVC_Response::from_wp_http_response( $response );
}
return new XPress_MVC_Response( $response );
}
/**
* Builds a permalink for a given route id and an array of arguments.
*
* @since 0.1.0
*
* @param string $route_id Route to build the permalink.
* @param array $arguments An array where each argument is a key and contains the value to be used in the route url.
* @return string|null The route permalink with the arguments populated or null if invalid $route_id.
*/
function xpress_mvc_get_route_permalink( $route_id, $arguments = array() ) {
return xpress_mvc_get_server()->get_route_permalink( $route_id, $arguments );
}
/**
* Registers a route
*
* @since 0.2.0
*
* @param string $route_id The route ID.
* @param string $route The REST route.
* @param array $args Route arguments.
* @param bool $override Optional. Whether the route should be overridden if it already exists.
* Default false.
*/
function xpress_mvc_register_route( $route_id, $route, $args, $override = false ) {
xpress_mvc_get_server()->register_route( $route_id, $route, $args, $override );
}
/**
* Unregisters a route
*
* @since 0.2.0
*
* @param string $route_id The route ID.
*/
function xpress_mvc_unregister_route( $route_id ) {
xpress_mvc_get_server()->unregister_route( $route_id );
}