{"id":283287,"date":"2026-03-09T09:34:35","date_gmt":"2026-03-09T09:34:35","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/todogift-shipping-api\/"},"modified":"2026-03-09T09:56:05","modified_gmt":"2026-03-09T09:56:05","slug":"todogift-shipping-api","status":"publish","type":"plugin","link":"https:\/\/tl.wordpress.org\/plugins\/todogift-shipping-api\/","author":23464724,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_crdt_document":"","version":"1.0.1","stable_tag":"1.0.1","tested":"6.9.4","requires":"5.3","requires_php":"7.4","requires_plugins":null,"header_name":"Todogift Shipping API","header_author":"Todogift","header_description":"Exposes a REST endpoint to calculate WooCommerce shipping rates (address + line_items) so the Todogift backend can retrieve store-computed shipping costs.","assets_banners_color":"","last_updated":"2026-03-09 09:56:05","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"","header_author_uri":"https:\/\/www.todogift.fr","rating":0,"author_block_rating":0,"active_installs":0,"downloads":235,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.1":{"tag":"1.0.1","author":"maicene","date":"2026-03-09 09:56:05"}},"upgrade_notice":[],"ratings":[],"assets_icons":{"icon-128X128.png":{"filename":"icon-128X128.png","revision":3477924,"resolution":"128x128","location":"assets","locale":""},"icon-256X256.png":{"filename":"icon-256X256.png","revision":3477924,"resolution":"256x256","location":"assets","locale":""}},"assets_banners":[],"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.0.1"],"block_files":[],"assets_screenshots":[],"screenshots":[],"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[1556,23853,3546,286],"plugin_category":[45],"plugin_contributors":[257342],"plugin_business_model":[],"class_list":["post-283287","plugin","type-plugin","status-publish","hentry","plugin_tags-api","plugin_tags-rest-api","plugin_tags-shipping","plugin_tags-woocommerce","plugin_category-ecommerce","plugin_contributors-maicene","plugin_committers-maicene"],"banners":[],"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/todogift-shipping-api\/assets\/icon-128X128.png?rev=3477924","icon_2x":"https:\/\/ps.w.org\/todogift-shipping-api\/assets\/icon-256X256.png?rev=3477924","generated":false},"screenshots":[],"raw_content":"<!--section=description-->\n<p>Todogift Shipping API exposes a simple, production-focused REST API endpoint so an external service can retrieve shipping rates calculated by WooCommerce on a vendor's store.<\/p>\n\n<p>This plugin is primarily built for stores integrating with the Todogift platform. It can also be used by any external system that needs authenticated access to WooCommerce-calculated shipping rates.<\/p>\n\n<p>This plugin does not re-implement shipping logic. It delegates to WooCommerce shipping calculation, so all configured rules apply:<\/p>\n\n<ul>\n<li>Shipping zones and locations<\/li>\n<li>Shipping methods (Flat rate, Free shipping, etc.)<\/li>\n<li>Table\/weight\/amount rules from shipping plugins (e.g. relay \/ carrier plugins)<\/li>\n<\/ul>\n\n<h4>Endpoints<\/h4>\n\n<ul>\n<li>GET \/wp-json\/todogift\/v1\/status (auth required)<\/li>\n<li>GET \/wp-json\/todogift\/v1\/shipping\/free-shipping-rules (auth required; core WooCommerce Free shipping min amount rules)<\/li>\n<li>POST \/wp-json\/todogift\/v1\/shipping\/calculate (auth required)<\/li>\n<\/ul>\n\n<h4>Authentication<\/h4>\n\n<p>All endpoints require authentication using WooCommerce REST API keys.<\/p>\n\n<p>For security, always use HTTPS and HTTP Basic Auth when calling the API. Do not transmit API keys over plain HTTP.<\/p>\n\n<h4>Privacy<\/h4>\n\n<p>The plugin does not track users and does not send data to third-party servers by itself. It only responds to authenticated API requests.<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Upload the <code>todogift-shipping-api<\/code> folder to the <code>\/wp-content\/plugins\/<\/code> directory.<\/li>\n<li>Activate the plugin through the 'Plugins' menu in WordPress.<\/li>\n<li>Ensure WooCommerce is installed and active.<\/li>\n<li>Create WooCommerce REST API keys (WooCommerce \u2192 Settings \u2192 Advanced \u2192 REST API) and share them with your integration.<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id=\"does%20this%20plugin%20send%20any%20data%20to%20todogift%20automatically%3F\"><h3>Does this plugin send any data to Todogift automatically?<\/h3><\/dt>\n<dd><p>No. The plugin only responds to authenticated API requests. It does not phone home.<\/p><\/dd>\n<dt id=\"what%20data%20is%20exposed%20by%20the%20api%3F\"><h3>What data is exposed by the API?<\/h3><\/dt>\n<dd><p>The <code>shipping\/calculate<\/code> endpoint returns shipping rates for a provided address and product IDs. It does not return customer account data. Access is restricted by WooCommerce REST API keys.<\/p><\/dd>\n<dt id=\"does%20this%20plugin%20require%20a%20todogift%20account%3F\"><h3>Does this plugin require a Todogift account?<\/h3><\/dt>\n<dd><p>To use it with Todogift, you will need a Todogift integration. Without Todogift (or another integration calling the endpoints), the plugin has no user-facing UI and simply exposes authenticated endpoints.<\/p><\/dd>\n<dt id=\"is%20this%20compatible%20with%20all%20shipping%20plugins%3F\"><h3>Is this compatible with all shipping plugins?<\/h3><\/dt>\n<dd><p>The plugin relies on WooCommerce shipping calculation. Compatibility depends on whether the installed shipping plugins properly register rates via WooCommerce shipping APIs.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.0.1<\/h4>\n\n<ul>\n<li>Shipping rates response now includes method_id and instance_id (WooCommerce shipping method identifiers).<\/li>\n<\/ul>\n\n<h4>1.0.0<\/h4>\n\n<ul>\n<li>Initial release: calculate shipping endpoint.<\/li>\n<li>Added status endpoint and free-shipping rules endpoint.<\/li>\n<\/ul>","raw_excerpt":"Expose a REST endpoint that returns WooCommerce-calculated shipping rates for a given address and products list.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/283287","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=283287"}],"author":[{"embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/maicene"}],"wp:attachment":[{"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=283287"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=283287"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=283287"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=283287"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=283287"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/tl.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=283287"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}