-
Notifications
You must be signed in to change notification settings - Fork 137
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Simplify public route redirection by using template_redirect #575
Conversation
is_admin() || | ||
is_customize_preview() || | ||
( function_exists( 'is_graphql_http_request' ) && is_graphql_http_request() ) || // From https://wordpress.org/plugins/wp-graphql/. | ||
! empty( $query->query_vars['rest_oauth1'] ) || // From https://oauth1.wp-api.org/. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@nickcernis Could you share any context on why this line was required? It seems like most oauth1 requests would have been covered by the defined( 'REST_REQUEST' )
check above, so I want to make sure I'm not missing something by removing it here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@apmatthews I'd read that REST_REQUEST
was undefined if a site is using Plain permalinks, but looking again I'm not sure that's true: https://github.com/WordPress/WordPress/blob/d2694aa46647af48d1bcaff48a4f6cac7f5cf470/wp-includes/rest-api.php#L360
I think it's safe to remove it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
* refactor: simplify public route redirection by using template_redirect (#575) * Update API Router `import` in Auth Docs (#580) * doc: (#519) adding examples for getStaticPaths * Update API Router auth import docs * Update API Router imports to use `@faustjs/core/api` Co-authored-by: William Johnston <[email protected]> Co-authored-by: Andrew Matthews <[email protected]> Co-authored-by: William Johnston <[email protected]>
* refactor: simplify public route redirection by using template_redirect (#575) * Update API Router `import` in Auth Docs (#580) * doc: (#519) adding examples for getStaticPaths * Update API Router auth import docs * Update API Router imports to use `@faustjs/core/api` Co-authored-by: William Johnston <[email protected]> * chore: remove unused wp-env dependency * chore: use Faust WP in comment text * chore: set minimum PHP to 7.2 * refactor: text domain wpe-headless -> faustwp * refactor: global consts WPE_HEADLESS -> FAUSTWP * refactor: replace function prefixes with namespace * refactor: settings slug to faustwp-settings * refactor: local variable prefixes to faustwp * refactor: filter prefixes wpe_headless -> faustwp * refactor: script handle prefixes to faustwp * refactor: id attribute prefix to faustwp * refactor: REST API namespace wpac -> faustwp * style: phpcs * Revert "refactor: REST API namespace wpac -> faustwp" This reverts commit 30d4488. * chore: add license file and plugin headers * style: change Faust WP to FaustWP * fix: remove redirect to settings on activation (#595) * Setup GitHub Actions for Testing/Linting Plugin (#582) * Lint plugin * Run unit tests via docker/github actions * Use -T in docker-compose * Use docker command instead of docker compose * Remove interactive tty * List files in dir * Simplify docker from * Fix wp-cli * Use wp cli from run step * Run unit test on windows * Test docker unit tests with macos * Remove volume from docker compose * inspect container * Add working-directory to inspect step * Use entrypoint/cmd * Sleep for 30 secs * Link db * Try simplifying testing env * Use more verbose phpunit command * Check current dir * Composer install * Clean up test action * Set sleep to 15 seconds * Fix CircleCI test * Update documentation * Update action names * chore: update plugin URI (#596) * refactor: Remove CircleCI Config (#597) * Update plugin file and folder name to faustwp (#600) * chore: delete unused wp-env config * chore: prepare for plugin file/folder rename * refactor: plugin file/folder name to faustwp * chore: update WPE Headless to FaustWP * test: update e2e test db * Core refactor (#601) * #590 exporting auth, moving all exports into export folder * #590 exporting utils * #590 exporting config * #590 exporting client * #590 removing most of schema.generated, exporting only getClient, config, and related types * #590 Headless -> Faust.js * #590 HeadlessConfig -> Config * #590 HeadlessConfig -> ClientConfig * chore: changeset * fix: core test imports * chore: updating packages * fix: only one failing test based on no exports support from jest 27 * fix: fixing tests, updating dependencies * Create E2E action (#599) * Create E2E action * Setup PHP and Node * Ensure frontend process doesn't hang * Don't use docker compose in exec scripts * Add sleep for DB to accept connections * Add working directory to setup tests step * Use Allow root wp cli * Setup chrome * Fix chrome version step syntax * Chrome/ChromeDriver is already installed on action * Add chrome driver args for GH Actions * e2e Click preview link and determine if correct preview page is fetched * Revert preview link href assertion removal * Wait for previewlinks.js to modify button href before checking preview link * fix: headless post previews URL (#602) * Version Packages (#603) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore: start unreleased changelog for FaustWP (#604) * chore: Upload test artifact upon failure (#606) * chore: Upload test artifact upon failure * fix: increase wait time for preview test to 14 seconds * Rename settings option to faustwp_settings (#607) * refactor: rename settings option to faustwp_settings * feat: add database upgrade functions * Release `faustwp` plugin action (#608) * feat: create wordpress.org deploy GH action * docs: reflect new release steps * chore: add dist ignore for plugin release * chore: copy 10up action src * refactor: option to specify plugin src dir * refactor: use release-pugin local action * fix: e2e plugin npm deps install (#609) * fix: NPM deps install * Squashed commit of the following: commit 40d08d0 Author: William Johnston <[email protected]> Date: Fri Oct 22 13:47:00 2021 -0700 fix: exporting components from declaration commit 145ef99 Merge: 632a57f 4d7f981 Author: William Johnston <[email protected]> Date: Fri Oct 22 10:46:13 2021 -0700 Merge branch 'canary' into next-refactor commit 632a57f Author: William Johnston <[email protected]> Date: Fri Oct 22 10:05:38 2021 -0700 feat: (#591) adding changeset denoting breaking change commit 7f2a760 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:55:23 2021 -0700 feat: (#591) limiting root @faustjs/next exports to those needed by client commit b1ba602 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:48:03 2021 -0700 feat: (#591) creating @faustjs/next/components export commit e4ad3ea Author: William Johnston <[email protected]> Date: Fri Oct 22 09:46:28 2021 -0700 feat: (#591) creating @faustjs/next/server export commit 69b6321 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:43:46 2021 -0700 feat: (#591) creating @faustjs/next/log export commit 9be7e1d Author: William Johnston <[email protected]> Date: Fri Oct 22 09:41:23 2021 -0700 feat: (#591) creating @faustjs/next/config export commit 664bb90 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:38:01 2021 -0700 feat: (#591) creating @faustjs/next/utils export commit 38888e8 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:36:51 2021 -0700 feat: (#591) migrating to src/gqty and exposing @faustjs/next/client * fix: add build step * refactor: use dev:next:getting-started command * Revert "Squashed commit of the following:" This reverts commit d15356f. * Next refactor (#605) * feat: (#591) migrating to src/gqty and exposing @faustjs/next/client * feat: (#591) creating @faustjs/next/utils export * feat: (#591) creating @faustjs/next/config export * feat: (#591) creating @faustjs/next/log export * feat: (#591) creating @faustjs/next/server export * feat: (#591) creating @faustjs/next/components export * feat: (#591) limiting root @faustjs/next exports to those needed by client * feat: (#591) adding changeset denoting breaking change * fix: exporting components from declaration Co-authored-by: Blake Wilson <[email protected]> * Version Packages (#613) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore: remove react example (#618) * docs: update tutorial sidebar label (#620) * Grammar Dev Env Setup (#630) * Grammar edits to basic headless site (#629) * Breakout Hooks Docs into Seperate Pages (#632) * doc: (#519) adding examples for getStaticPaths * Update API Router auth import docs * Update API Router imports to use `@faustjs/core/api` * Breakout Hooks into individual Pages (#631) * docs: break out hooks * Update links to appropriate hooks url * Logging queries guide * Fix docs site URLs * Fix hooks links Co-authored-by: William Johnston <[email protected]> Co-authored-by: Andrew Matthews <[email protected]> Co-authored-by: William Johnston <[email protected]> Co-authored-by: Will Johnston <[email protected]> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Nate Archer <[email protected]>
* refactor: simplify public route redirection by using template_redirect (#575) * Update API Router `import` in Auth Docs (#580) * doc: (#519) adding examples for getStaticPaths * Update API Router auth import docs * Update API Router imports to use `@faustjs/core/api` Co-authored-by: William Johnston <[email protected]> * chore: remove unused wp-env dependency * chore: use Faust WP in comment text * chore: set minimum PHP to 7.2 * refactor: text domain wpe-headless -> faustwp * refactor: global consts WPE_HEADLESS -> FAUSTWP * refactor: replace function prefixes with namespace * refactor: settings slug to faustwp-settings * refactor: local variable prefixes to faustwp * refactor: filter prefixes wpe_headless -> faustwp * refactor: script handle prefixes to faustwp * refactor: id attribute prefix to faustwp * refactor: REST API namespace wpac -> faustwp * style: phpcs * Revert "refactor: REST API namespace wpac -> faustwp" This reverts commit 30d4488. * chore: add license file and plugin headers * style: change Faust WP to FaustWP * fix: remove redirect to settings on activation (#595) * Setup GitHub Actions for Testing/Linting Plugin (#582) * Lint plugin * Run unit tests via docker/github actions * Use -T in docker-compose * Use docker command instead of docker compose * Remove interactive tty * List files in dir * Simplify docker from * Fix wp-cli * Use wp cli from run step * Run unit test on windows * Test docker unit tests with macos * Remove volume from docker compose * inspect container * Add working-directory to inspect step * Use entrypoint/cmd * Sleep for 30 secs * Link db * Try simplifying testing env * Use more verbose phpunit command * Check current dir * Composer install * Clean up test action * Set sleep to 15 seconds * Fix CircleCI test * Update documentation * Update action names * chore: update plugin URI (#596) * refactor: Remove CircleCI Config (#597) * Update plugin file and folder name to faustwp (#600) * chore: delete unused wp-env config * chore: prepare for plugin file/folder rename * refactor: plugin file/folder name to faustwp * chore: update WPE Headless to FaustWP * test: update e2e test db * Core refactor (#601) * #590 exporting auth, moving all exports into export folder * #590 exporting utils * #590 exporting config * #590 exporting client * #590 removing most of schema.generated, exporting only getClient, config, and related types * #590 Headless -> Faust.js * #590 HeadlessConfig -> Config * #590 HeadlessConfig -> ClientConfig * chore: changeset * fix: core test imports * chore: updating packages * fix: only one failing test based on no exports support from jest 27 * fix: fixing tests, updating dependencies * Create E2E action (#599) * Create E2E action * Setup PHP and Node * Ensure frontend process doesn't hang * Don't use docker compose in exec scripts * Add sleep for DB to accept connections * Add working directory to setup tests step * Use Allow root wp cli * Setup chrome * Fix chrome version step syntax * Chrome/ChromeDriver is already installed on action * Add chrome driver args for GH Actions * e2e Click preview link and determine if correct preview page is fetched * Revert preview link href assertion removal * Wait for previewlinks.js to modify button href before checking preview link * fix: headless post previews URL (#602) * Version Packages (#603) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore: start unreleased changelog for FaustWP (#604) * chore: Upload test artifact upon failure (#606) * chore: Upload test artifact upon failure * fix: increase wait time for preview test to 14 seconds * Rename settings option to faustwp_settings (#607) * refactor: rename settings option to faustwp_settings * feat: add database upgrade functions * Release `faustwp` plugin action (#608) * feat: create wordpress.org deploy GH action * docs: reflect new release steps * chore: add dist ignore for plugin release * chore: copy 10up action src * refactor: option to specify plugin src dir * refactor: use release-pugin local action * fix: e2e plugin npm deps install (#609) * fix: NPM deps install * Squashed commit of the following: commit 40d08d0 Author: William Johnston <[email protected]> Date: Fri Oct 22 13:47:00 2021 -0700 fix: exporting components from declaration commit 145ef99 Merge: 632a57f 4d7f981 Author: William Johnston <[email protected]> Date: Fri Oct 22 10:46:13 2021 -0700 Merge branch 'canary' into next-refactor commit 632a57f Author: William Johnston <[email protected]> Date: Fri Oct 22 10:05:38 2021 -0700 feat: (#591) adding changeset denoting breaking change commit 7f2a760 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:55:23 2021 -0700 feat: (#591) limiting root @faustjs/next exports to those needed by client commit b1ba602 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:48:03 2021 -0700 feat: (#591) creating @faustjs/next/components export commit e4ad3ea Author: William Johnston <[email protected]> Date: Fri Oct 22 09:46:28 2021 -0700 feat: (#591) creating @faustjs/next/server export commit 69b6321 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:43:46 2021 -0700 feat: (#591) creating @faustjs/next/log export commit 9be7e1d Author: William Johnston <[email protected]> Date: Fri Oct 22 09:41:23 2021 -0700 feat: (#591) creating @faustjs/next/config export commit 664bb90 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:38:01 2021 -0700 feat: (#591) creating @faustjs/next/utils export commit 38888e8 Author: William Johnston <[email protected]> Date: Fri Oct 22 09:36:51 2021 -0700 feat: (#591) migrating to src/gqty and exposing @faustjs/next/client * fix: add build step * refactor: use dev:next:getting-started command * Revert "Squashed commit of the following:" This reverts commit d15356f. * Next refactor (#605) * feat: (#591) migrating to src/gqty and exposing @faustjs/next/client * feat: (#591) creating @faustjs/next/utils export * feat: (#591) creating @faustjs/next/config export * feat: (#591) creating @faustjs/next/log export * feat: (#591) creating @faustjs/next/server export * feat: (#591) creating @faustjs/next/components export * feat: (#591) limiting root @faustjs/next exports to those needed by client * feat: (#591) adding changeset denoting breaking change * fix: exporting components from declaration Co-authored-by: Blake Wilson <[email protected]> * Version Packages (#613) Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> * chore: remove react example (#618) * docs: update tutorial sidebar label (#620) * Grammar Dev Env Setup (#630) * Grammar edits to basic headless site (#629) * Breakout Hooks Docs into Seperate Pages (#632) * doc: (#519) adding examples for getStaticPaths * Update API Router auth import docs * Update API Router imports to use `@faustjs/core/api` * Breakout Hooks into individual Pages (#631) * docs: break out hooks * Update links to appropriate hooks url * Logging queries guide * Fix docs site URLs * Fix hooks links Co-authored-by: William Johnston <[email protected]> Co-authored-by: Andrew Matthews <[email protected]> Co-authored-by: William Johnston <[email protected]> Co-authored-by: Will Johnston <[email protected]> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Nate Archer <[email protected]>
Fixes #389
In testing, it appears switching from
parse_request
totemplate_redirect
works as intended and allows us to remove most of the complexity in the callback. The only conditional check that could not be avoided wasis_customize_preview()
. I'm not sure that accessing the customizer preview is really necessary or useful in a headless environment, but I left it in place since we were already making the exception.