pop-api / api
Component-based API
Requires
- php: ^8.1
- getpop/engine: ^9.0
Requires (Dev)
- getpop/access-control: ^9.0
- getpop/cache-control: ^9.0
- phpstan/phpstan: ^1.8
- phpunit/phpunit: ^10.2
- rector/rector: ^0.18
- squizlabs/php_codesniffer: ^3.6
Suggests
- getpop/access-control: Integration with Access Control
- getpop/cache-control: Integration with Cache Control
Conflicts
- gatographql-standalone/gatographql: <9.0.0
- gatographql/external-dependency-wrappers: <9.0.0
- gatographql/gatographql: <9.0.0
- gatographql/plugin-utils: <9.0.0
- gatographql/testing-schema: <9.0.0
- getpop/access-control: <9.0.0
- getpop/cache-control: <9.0.0
- getpop/component-model: <9.0.0
- getpop/componentrouting: <9.0.0
- getpop/definitions: <9.0.0
- getpop/dom-crawler: <9.0.0
- getpop/engine-wp: <9.0.0
- getpop/engine-wp-bootloader: <9.0.0
- getpop/filestore: <9.0.0
- getpop/graphql-parser: <9.0.0
- getpop/guzzle-http: <9.0.0
- getpop/loosecontracts: <9.0.0
- getpop/mandatory-directives-by-configuration: <9.0.0
- getpop/markdown-convertor: <9.0.0
- getpop/root: <9.0.0
- getpop/root-wp: <9.0.0
- graphql-by-pop/graphiql: <9.0.0
- graphql-by-pop/graphql-clients-for-wp: <9.0.0
- graphql-by-pop/graphql-endpoint-for-wp: <9.0.0
- graphql-by-pop/graphql-request: <9.0.0
- graphql-by-pop/graphql-server: <9.0.0
- graphql-by-pop/graphql-voyager: <9.0.0
- phpunit-for-gatographql/dummy-schema: <9.0.0
- phpunit-for-gatographql/dummy-wp-schema: <9.0.0
- phpunit-for-gatographql/gatographql: <9.0.0
- phpunit-for-gatographql/gatographql-testing: <9.0.0
- phpunit-for-gatographql/webserver-requests: <9.0.0
- phpunit-for-gatographql/wpfaker-schema: <9.0.0
- pop-api/api-clients: <9.0.0
- pop-api/api-endpoints: <9.0.0
- pop-api/api-endpoints-for-wp: <9.0.0
- pop-api/api-graphql: <9.0.0
- pop-api/api-mirrorquery: <9.0.0
- pop-api/api-rest: <9.0.0
- pop-backbone/php-hooks: <9.0.0
- pop-backbone/wp-data-parser: <9.0.0
- pop-cms-schema/categories: <9.0.0
- pop-cms-schema/categories-wp: <9.0.0
- pop-cms-schema/category-mutations: <9.0.0
- pop-cms-schema/category-mutations-wp: <9.0.0
- pop-cms-schema/comment-mutations: <9.0.0
- pop-cms-schema/comment-mutations-wp: <9.0.0
- pop-cms-schema/commentmeta: <9.0.0
- pop-cms-schema/commentmeta-wp: <9.0.0
- pop-cms-schema/comments: <9.0.0
- pop-cms-schema/comments-wp: <9.0.0
- pop-cms-schema/custompost-categories-wp: <9.0.0
- pop-cms-schema/custompost-category-mutations: <9.0.0
- pop-cms-schema/custompost-category-mutations-wp: <9.0.0
- pop-cms-schema/custompost-mutations: <9.0.0
- pop-cms-schema/custompost-mutations-wp: <9.0.0
- pop-cms-schema/custompost-tag-mutations: <9.0.0
- pop-cms-schema/custompost-tag-mutations-wp: <9.0.0
- pop-cms-schema/custompost-tags-wp: <9.0.0
- pop-cms-schema/custompost-user-mutations: <9.0.0
- pop-cms-schema/custompost-user-mutations-wp: <9.0.0
- pop-cms-schema/custompostmedia: <9.0.0
- pop-cms-schema/custompostmedia-mutations: <9.0.0
- pop-cms-schema/custompostmedia-mutations-wp: <9.0.0
- pop-cms-schema/custompostmedia-wp: <9.0.0
- pop-cms-schema/custompostmeta: <9.0.0
- pop-cms-schema/custompostmeta-wp: <9.0.0
- pop-cms-schema/customposts: <9.0.0
- pop-cms-schema/customposts-wp: <9.0.0
- pop-cms-schema/media: <9.0.0
- pop-cms-schema/media-mutations: <9.0.0
- pop-cms-schema/media-mutations-wp: <9.0.0
- pop-cms-schema/media-wp: <9.0.0
- pop-cms-schema/menus: <9.0.0
- pop-cms-schema/menus-wp: <9.0.0
- pop-cms-schema/meta: <9.0.0
- pop-cms-schema/metaquery-wp: <9.0.0
- pop-cms-schema/page-mutations: <9.0.0
- pop-cms-schema/page-mutations-wp: <9.0.0
- pop-cms-schema/pagemedia-mutations: <9.0.0
- pop-cms-schema/pages: <9.0.0
- pop-cms-schema/pages-wp: <9.0.0
- pop-cms-schema/post-categories: <9.0.0
- pop-cms-schema/post-categories-wp: <9.0.0
- pop-cms-schema/post-category-mutations: <9.0.0
- pop-cms-schema/post-mutations: <9.0.0
- pop-cms-schema/post-tag-mutations: <9.0.0
- pop-cms-schema/post-tags: <9.0.0
- pop-cms-schema/post-tags-wp: <9.0.0
- pop-cms-schema/postmedia-mutations: <9.0.0
- pop-cms-schema/posts: <9.0.0
- pop-cms-schema/posts-wp: <9.0.0
- pop-cms-schema/queriedobject: <9.0.0
- pop-cms-schema/queriedobject-wp: <9.0.0
- pop-cms-schema/schema-commons: <9.0.0
- pop-cms-schema/schema-commons-wp: <9.0.0
- pop-cms-schema/settings: <9.0.0
- pop-cms-schema/settings-wp: <9.0.0
- pop-cms-schema/tag-mutations: <9.0.0
- pop-cms-schema/tag-mutations-wp: <9.0.0
- pop-cms-schema/tags: <9.0.0
- pop-cms-schema/tags-wp: <9.0.0
- pop-cms-schema/taxonomies: <9.0.0
- pop-cms-schema/taxonomies-wp: <9.0.0
- pop-cms-schema/taxonomy-mutations: <9.0.0
- pop-cms-schema/taxonomy-mutations-wp: <9.0.0
- pop-cms-schema/taxonomymeta: <9.0.0
- pop-cms-schema/taxonomymeta-wp: <9.0.0
- pop-cms-schema/taxonomyquery: <9.0.0
- pop-cms-schema/taxonomyquery-wp: <9.0.0
- pop-cms-schema/user-avatars: <9.0.0
- pop-cms-schema/user-avatars-wp: <9.0.0
- pop-cms-schema/user-roles: <9.0.0
- pop-cms-schema/user-roles-wp: <9.0.0
- pop-cms-schema/user-state: <9.0.0
- pop-cms-schema/user-state-mutations: <9.0.0
- pop-cms-schema/user-state-mutations-wp: <9.0.0
- pop-cms-schema/user-state-wp: <9.0.0
- pop-cms-schema/usermeta: <9.0.0
- pop-cms-schema/usermeta-wp: <9.0.0
- pop-cms-schema/users: <9.0.0
- pop-cms-schema/users-wp: <9.0.0
- pop-schema/directive-commons: <9.0.0
- pop-schema/extended-schema-commons: <9.0.0
- pop-schema/http-requests: <9.0.0
- pop-schema/schema-commons: <9.0.0
- pop-wp-schema/block-content-parser: <9.0.0
- pop-wp-schema/blocks: <9.0.0
- pop-wp-schema/commentmeta: <9.0.0
- pop-wp-schema/comments: <9.0.0
- pop-wp-schema/custompostmeta: <9.0.0
- pop-wp-schema/customposts: <9.0.0
- pop-wp-schema/media: <9.0.0
- pop-wp-schema/menus: <9.0.0
- pop-wp-schema/meta: <9.0.0
- pop-wp-schema/multisite: <9.0.0
- pop-wp-schema/pages: <9.0.0
- pop-wp-schema/posts: <9.0.0
- pop-wp-schema/schema-commons: <9.0.0
- pop-wp-schema/settings: <9.0.0
- pop-wp-schema/site: <9.0.0
- pop-wp-schema/taxonomymeta: <9.0.0
- pop-wp-schema/usermeta: <9.0.0
- pop-wp-schema/users: <9.0.0
- dev-master / 9.1.x-dev
- 9.0.0
- 8.0.0
- 7.0.8
- 7.0.7
- 7.0.6
- 7.0.5
- 7.0.4
- 7.0.3
- 7.0.2
- 7.0.1
- 7.0.0
- 6.0.2
- 6.0.1
- 6.0.0
- 5.0.0
- 4.2.0
- 4.1.1
- 4.1.0
- 4.0.1
- 4.0.0
- 3.0.0
- 2.6.1
- 2.6.0
- 2.5.2
- 2.5.1
- 2.5.0
- 2.4.1
- 2.4.0
- 2.3.0
- 2.2.3
- 2.2.2
- 2.2.1
- 2.2.0
- 2.1.3
- 2.1.2
- 2.1.1
- 2.1.0
- 2.0.1
- 2.0.0
- 1.6.0
- 1.5.5
- 1.5.4
- 1.5.3
- 1.5.2
- 1.5.1
- 1.5.0
- 1.4.0
- 1.3.1
- 1.3.0
- 1.2.0
- 1.1.1
- 1.1.0
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.10.2
- 0.10.1
- 0.10.0
- 0.9.10
- 0.9.9
- 0.9.8
- 0.9.7
- 0.9.6
- 0.9.5
- 0.9.4
- 0.9.3
- 0.9.2
- 0.9.1
- 0.9.0
- 0.8.9
- 0.8.8
- 0.8.7
- 0.8.6
- 0.8.5
- 0.8.4
- v0.8.3
- v0.8.2
- 0.8.1
- 0.7.13
- 0.7.12
- 0.7.11
- 0.7.10
- 0.7.9
- 0.7.8
- 0.7.7
- 0.7.6
This package is auto-updated.
Last update: 2024-12-16 10:17:59 UTC
README
Convert the application into a powerful API. Install the Gato GraphQL package to convert it into a GraphQL server, and the REST API package to enable adding REST endpoints.
Install
Installing a fully-working API
Follow the instructions under Bootstrap a PoP API for WordPress (even though CMS-agnostic, only the WordPress adapters have been presently implemented).
Installing this library
Via Composer
composer require pop-api/api
Enable pretty permalinks
Apache
Add the following code in the .htaccess
file to enable API endpoint /api/
:
<IfModule mod_rewrite.c> RewriteEngine On RewriteBase / # Rewrite from /some-url/api/ to /some-url/?scheme=api RewriteCond %{SCRIPT_FILENAME} !-d RewriteCond %{SCRIPT_FILENAME} !-f RewriteRule ^(.*)/api/?$ /$1/?scheme=api [L,P,QSA] # Rewrite from api/ to /?scheme=api RewriteCond %{SCRIPT_FILENAME} !-d RewriteCond %{SCRIPT_FILENAME} !-f RewriteRule ^api/?$ /?scheme=api [L,P,QSA] </IfModule>
To add pretty API endpoints for the extensions (GraphQL => /api/graphql/
), REST => /api/rest/
), add the following code to file .htaccess
:
<IfModule mod_rewrite.c> RewriteEngine On RewriteBase / # a. Resource endpoints # 1 and 2. GraphQL or REST: Rewrite from /some-url/api/(graphql|rest)/ to /some-url/?scheme=api&datastructure=(graphql|rest) RewriteCond %{SCRIPT_FILENAME} !-d RewriteCond %{SCRIPT_FILENAME} !-f RewriteRule ^(.*)/api/(graphql|rest)/?$ /$1/?scheme=api&datastructure=$2 [L,P,QSA] # b. Homepage single endpoint (root) # 1 and 2. GraphQL or REST: Rewrite from api/(graphql|rest)/ to /?scheme=api&datastructure=(graphql|rest) RewriteCond %{SCRIPT_FILENAME} !-d RewriteCond %{SCRIPT_FILENAME} !-f RewriteRule ^api/(graphql|rest)/?$ /?scheme=api&datastructure=$1 [L,P,QSA] </IfModule>
Nginx
Add the following code in the Nginx configuration's server
entry, to enable API endpoint /api/
. Please notice that the resolver below is the one for Docker; replace this value for your environment.
location ~ ^(.*)/api/?$ { # Resolver for Docker. Change to your own resolver 127.0.0.11 [::1]; # If adding $args and it's empty, it does a redirect from /api/ to ?scheme=api. # Then, add $args only if not empty set $redirect_uri "$scheme://$server_name$1/?scheme=api"; if ($args) { set $redirect_uri "$scheme://$server_name$1/?$args&scheme=api"; } proxy_pass $redirect_uri; }
To add pretty API endpoints for the extensions (GraphQL => /api/graphql/
), REST => /api/rest/
), add the following code:
location ~ ^(.*)/api/(rest|graphql)/?$ { # Resolver for Docker. Change to your own resolver 127.0.0.11 [::1]; set $redirect_uri "$scheme://$server_name$1/?scheme=api&datastructure=$2"; if ($args) { set $redirect_uri "$scheme://$server_name$1/?$args&scheme=api&datastructure=$2"; } proxy_pass $redirect_uri; }
Development
The source code is hosted on the GatoGraphQL monorepo, under API/packages/api
.
Usage
Initialize the component:
\PoP\Root\App::stockAndInitializeModuleClasses([([ \PoPAPI\API\Module::class, ]);
Note:
To enable GraphQL and/or REST endpoints, the corresponding package must be installed: GraphQL package, REST package
PHP versions
Requirements:
- PHP 8.1+ for development
- PHP 7.4+ for production
Supported PHP features
Check the list of Supported PHP features in GatoGraphQL/GatoGraphQL
Preview downgrade to PHP 7.4
Via Rector (dry-run mode):
composer preview-code-downgrade
Standards
To check the coding standards via PHP CodeSniffer, run:
composer check-style
To automatically fix issues, run:
composer fix-style
Change log
Please see CHANGELOG for more information on what has changed recently.
Testing
To execute PHPUnit, run:
composer test
Static Analysis
To execute PHPStan, run:
composer analyse
Report issues
To report a bug or request a new feature please do it on the GatoGraphQL monorepo issue tracker.
Contributing
We welcome contributions for this package on the GatoGraphQL monorepo (where the source code for this package is hosted).
Please see CONTRIBUTING and CODE_OF_CONDUCT for details.
Security
If you discover any security related issues, please email leo@getpop.org instead of using the issue tracker.
Credits
License
GNU General Public License v2 (or later). Please see License File for more information.