Play with curl to test generated JHipster application API

by Olivier Barais     jhipster   swagger   curl   authentification  

Posted 2017.04.12 — Rennes, France

I often used JHipster to create my Rest API. I often want to test this API using curl.
However, if you tak the curl command line method from swagger, it always misses the authentification mechanism.

To manage this authentification, you can use the following commands.

If you use oauth:

Generate the XSRF-TOKEN

Create the XSRF-TOKEN and save it to the file cookies.txt

curl -v -c cookies.txt -b cookies.txt http://yourserverip:8080/oauth/token

Manage the authentication

Do the authentification with admin, admin and save the session id to cookies.txt

curl -v -c cookies.txt -b cookies.txt 'http://yourserverip:8080/api/authentication' -H 'Accept: application/json, text/plain, */*'  -H 'Connection: keep-alive' -H 'Content-Type: application/x-www-form-urlencoded' -H 'Host: yourserverip.fr:8080' -H 'Referer: http://yourserverip:8080/'  -H "X-XSRF-TOKEN: `cat cookies.txt |grep XSRF-TOKEN | awk '{print $7}'`" --data 'j_username=admin&j_password=admin&remember-me=true&submit=Login'

Test your api

From the curl command line provided by swagger, you have to remove the --header 'X-XSRF-TOKEN: .... and add the -b cookies.txt

curl -b cookies.txt -X GET --header 'Accept: application/json'  'http://yourserverip:8080/api/account'

If you use JWT:

It is easier.

export ID=`curl  -X POST --header 'Content-Type: application/json' --header 'Accept: application/json' -d '{  "password": "admin",  "rememberMe": true,  "username": "admin"  }' 'https://yourserverip:8080/api/authenticate' | jq -r .id_token`

puis je passe ma requĂȘte en rĂ©utilisant ce token dans le header

curl  --header 'Content-Type: application/json' --header 'Accept: application/json' --header "Authorization: Bearer $ID" -d 'yourjson' 'https://yourserverip:8080/api/yourendpoint'

Enjoy ....