Skip to content

Commit

Permalink
API Fetch: Expose nonce on created middleware function (#13451)
Browse files Browse the repository at this point in the history
  • Loading branch information
aduth authored Jan 25, 2019
1 parent ff6b834 commit d28b228
Show file tree
Hide file tree
Showing 8 changed files with 46 additions and 43 deletions.
23 changes: 22 additions & 1 deletion lib/client-assets.php
Original file line number Diff line number Diff line change
Expand Up @@ -185,10 +185,31 @@ function gutenberg_register_scripts_and_styles() {
gutenberg_register_packages_scripts();

// Inline scripts.
global $wp_scripts;
if ( isset( $wp_scripts->registered['wp-api-fetch'] ) ) {
$wp_scripts->registered['wp-api-fetch']->deps[] = 'wp-hooks';
}
wp_add_inline_script(
'wp-api-fetch',
sprintf(
'wp.apiFetch.use( wp.apiFetch.createNonceMiddleware( "%s" ) );',
implode(
"\n",
array(
'( function() {',
' var nonceMiddleware = wp.apiFetch.createNonceMiddleware( "%s" );',
' wp.apiFetch.use( nonceMiddleware );',
' wp.hooks.addAction(',
' "heartbeat.tick",',
' "core/api-fetch/create-nonce-middleware",',
' function( response ) {',
' if ( response[ "rest_nonce" ] ) {',
' nonceMiddleware.nonce = response[ "rest_nonce" ];',
' }',
' }',
' )',
'} )()',
)
),
( wp_installing() && ! is_multisite() ) ? '' : wp_create_nonce( 'wp_rest' )
),
'after'
Expand Down
1 change: 0 additions & 1 deletion lib/packages-dependencies.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@
'wp-rich-text',
),
'wp-api-fetch' => array(
'wp-hooks',
'wp-i18n',
'wp-url',
),
Expand Down
1 change: 0 additions & 1 deletion package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 6 additions & 1 deletion packages/api-fetch/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
## 2.3.0 (Unreleased)
## 3.0.0 (Unreleased)

### Breaking Changes

- A created nonce middleware will no longer automatically listen for `heartbeat.tick` actions. Assign to the new `nonce` middleware property instead.

### New Feature

- The function returned by `createNonceMiddleware` includes an assignable `nonce` property corresponding to the active nonce to be used.
- Default fetch handler can be overridden with a custom fetch handler

## 2.2.6 (2018-12-12)
Expand Down
2 changes: 2 additions & 0 deletions packages/api-fetch/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,8 @@ const nonce = "nonce value";
apiFetch.use( apiFetch.createNonceMiddleware( nonce ) );
```

The function returned by `createNonceMiddleware` includes a `nonce` property corresponding to the actively used nonce. You may also assign to this property if you have a fresh nonce value to use.

**Root URL middleware**

```js
Expand Down
1 change: 0 additions & 1 deletion packages/api-fetch/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@
"react-native": "src/index",
"dependencies": {
"@babel/runtime": "^7.0.0",
"@wordpress/hooks": "file:../hooks",
"@wordpress/i18n": "file:../i18n",
"@wordpress/url": "file:../url"
},
Expand Down
53 changes: 15 additions & 38 deletions packages/api-fetch/src/middlewares/nonce.js
Original file line number Diff line number Diff line change
@@ -1,50 +1,27 @@
/**
* External dependencies
*/
import { addAction } from '@wordpress/hooks';
function createNonceMiddleware( nonce ) {
function middleware( options, next ) {
const { headers = {} } = options;

const createNonceMiddleware = ( nonce ) => {
let usedNonce = nonce;

/**
* This is not ideal but it's fine for now.
*
* Configure heartbeat to refresh the wp-api nonce, keeping the editor
* authorization intact.
*/
addAction( 'heartbeat.tick', 'core/api-fetch/create-nonce-middleware', ( response ) => {
if ( response[ 'rest-nonce' ] ) {
usedNonce = response[ 'rest-nonce' ];
}
} );

return function( options, next ) {
let headers = options.headers || {};
// If an 'X-WP-Nonce' header (or any case-insensitive variation
// thereof) was specified, no need to add a nonce header.
let addNonceHeader = true;
for ( const headerName in headers ) {
if ( headers.hasOwnProperty( headerName ) ) {
if ( headerName.toLowerCase() === 'x-wp-nonce' ) {
addNonceHeader = false;
break;
}
if ( headerName.toLowerCase() === 'x-wp-nonce' ) {
return next( options );
}
}

if ( addNonceHeader ) {
// Do not mutate the original headers object, if any.
headers = {
...headers,
'X-WP-Nonce': usedNonce,
};
}

return next( {
...options,
headers,
headers: {
...headers,
'X-WP-Nonce': middleware.nonce,
},
} );
};
};
}

middleware.nonce = nonce;

return middleware;
}

export default createNonceMiddleware;
1 change: 1 addition & 0 deletions packages/api-fetch/src/middlewares/test/nonce.js
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ describe( 'Nonce middleware', () => {
headers: { 'X-WP-Nonce': 'existing nonce' },
};
const callback = ( options ) => {
expect( options ).toBe( requestOptions );
expect( options.headers[ 'X-WP-Nonce' ] ).toBe( 'existing nonce' );
};

Expand Down

0 comments on commit d28b228

Please sign in to comment.