Get data from Woocommerce via server api
- 
 In the WooCommerce docs it says WooCommerce includes two ways to authenticate with the WP REST API. It is also possible to authenticate using any WP REST API authentication plugin or method. So I thought that meant I could use the JWT to access WooCommerce endpoints too. Second choice, if you want to use the token anyway, then you need to go with Wordpress REST API Yes this is what I want, how can I get the WooCommerce orders using the token? 
- 
 @d-healey said in Get data from Woocommerce via server api: Yes this is what I want, how can I get the WooCommerce orders using the token? I haven't tried that, but you need to use the token in the header; 
 https://docs.hise.audio/scripting/scripting-api/server/index.html#sethttpheaderActually I think you don't need this. Because if the username and password is correct, the system will provide the token. If not, it will give error. After checking the JWT Authentication, then you don't need to use the token, because there is an easier way with woocommerce REST API. But it is IMO. 
- 
 I haven't tried that, but you need to use the token in the header; I've tried this but it doesn't seem to be working, however it doesn't seem to be working with regular wordpress endpoints either so I think I need to check that I@m using JWT correctly first. there is an easier way with woocommerce REST API. But I can't use this because the secret key will not be secret. 
- 
 @d-healey said in Get data from Woocommerce via server api: But I can't use this because the secret key will not be secret. Do you think it can be retrieved by the hackers? :) 
- 
 @orange Yes, my project is open source. 
- 
 @d-healey Now I am trying to use the token in header but I couldn't get it work too. There should be something missing... 
- 
 @orange Oo what format are you using for the header? I've tried these two Server.setHttpHeader("Authorization = Bearer " + token); Server.setHttpHeader("Authorization: Bearer " + token);
- 
 @d-healey I used that one Server.setHttpHeader("Authorization: Bearer " + token);I guess we are using same plugin :) 
- 
 @orange I've installed a REST API log plugin { "data": { "code": "jwt_auth_no_auth_header", "message": "Authorization header not found.", "data": { "status": 403 } }, "headers": { "Allow": "POST" }, "status": 403 }So the header isn't being set, I will keep digging. 
- 
 @Christoph-Hart Any ideas? What format should the header be? 
- 
 The plot thickens... Setting the content-type header, like this Content-Type: text/htmlworks. Setting authorisation header like thisAuthorization: Bearer 123456doesn't work.I'm thinking it's something to do with my server configuration.... 
- 
 Finally got the damn thing working. I'm using a xampp test server. These are the things I did: Followed config settings here - https://wordpress.org/plugins/jwt-authentication-for-wp-rest-api/#description 
 AddedSetEnvIf Authorization "(.*)" HTTP_AUTHORIZATION=$1to apache config file: instructions here - https://stackoverflow.com/a/54729344/1901367
 Also did what this guy said, don't know if it's necessary though - https://www.web-design-talk.co.uk/126/getting-htaccess-mod-rewrite-working-locally-with-xampp/
- 
 @d-healey Oh yes, .htaccess file and wp-config file must be modified. Is customer purchase call working? 
 I am trying to get user info but response is"Sorry, you are not allowed to list users."I think same header issue is here too.I am using live server by the way. var encryptionData; Server.setBaseURL("https://website.com"); inline function onGetInfo_ButtonControl(component, value) { if(value) { local LockerPW = "987654321"; local FileDirectory = FileSystem.getFolder(FileSystem.UserPresets).getParentDirectory(); encryptionData = FileDirectory.getChildFile("credentials.dat").loadEncryptedObject(LockerPW); Server.setHttpHeader("Authorization: Bearer " + encryptionData.token); Server.callWithGET("wp-json/wp/v2/users", encryptionData.user_email, function(status, response) { local serv_resp = trace(response); Console.print("server response: " + serv_resp); }); } }; Content.getComponent("GetInfo_Button").setControlCallback(onGetInfo_ButtonControl);
- 
 Yes I modified htaccess but it didn't work on my testing server - xampp. I had to do the extra steps I put in my last post. 
- 
 Not sure if I understand this particular authentication system, but isn't the token supposed to be generated as a session cookie? - User logs in with credentials (email & password)
- Server returns a token when the login succeeds (might return a cached token if the requests are within a certain time).
- User uses this token for each subsequent URL request as proof of authentication (most likely in the header).
 
- 
 @Christoph-Hart Yes token system is supposed to be generated as a session cookie. Wordpress REST API can use this token system (JWT Auth) 
 Woocommerce REST API only uses OAuth system (consumer key and consumer secret codes method)Do you think consumer key and consumer secret codes can be compromised by hackers on a compiled plugin? 
- 
 @d-healey said in Get data from Woocommerce via server api: Yes I modified htaccess but it didn't work on my testing server - xampp. I had to do the extra steps I put in my last post. I applied that steps but my server system doesn't accept http header authenticaton. Keep digging... 
- 
 @orange said in Get data from Woocommerce via server api: @Christoph-Hart Yes token system is supposed to be generated as a session cookie. Wordpress REST API can use this token system (JWT Auth) 
 Woocommerce REST API only uses OAuth system (consumer key and consumer secret codes method)Do you think consumer key and consumer secret codes can be compromised by hackers on a compiled plugin? isn't consumer key = user ID/email address 
 consumer secret code = password? 
- 
 @Lindon said in Get data from Woocommerce via server api: @orange said in Get data from Woocommerce via server api: @Christoph-Hart Yes token system is supposed to be generated as a session cookie. Wordpress REST API can use this token system (JWT Auth) 
 Woocommerce REST API only uses OAuth system (consumer key and consumer secret codes method)Do you think consumer key and consumer secret codes can be compromised by hackers on a compiled plugin? isn't consumer key = user ID/email address 
 consumer secret code = password? Woocommerce doesn't alow to use it's REST API with directly using username and passwords while authentication. These two codes are generated within Woocommerce > Settings > Advanced > REST API > Add Key menu. So your app will use these codes to use Woo REST API. You can give permissions Read, Write or both depending on your needs. https://woocommerce.github.io/woocommerce-rest-api-docs/?shell#authentication 
- 
 @orange said in Get data from Woocommerce via server api: Yes token system is supposed to be generated as a session cookie. Then why do you save it in a file? Do you think consumer key and consumer secret codes can be compromised by hackers on a compiled plugin? Anything can be compromised. Things that are embedded in the plugin (RSA keys, static passwords in a script) can be extracted more easily than dynamic data that comes from the server (eg. these tokens), but then both things might be trivially easy for anybody with a good knowledge of reverse-debugging. 



