Skip to content
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

How to reuse the login logic #2110

Open
mangelozzi opened this issue Nov 1, 2023 · 6 comments
Open

How to reuse the login logic #2110

mangelozzi opened this issue Nov 1, 2023 · 6 comments
Labels
enhancement New feature or request topic: import

Comments

@mangelozzi
Copy link

Problem to solve

In order to query most API's one has to perform authorisation, e.g.:

POST https://example.com/webapi/Token
[FormParams]
userName: {{ username }}@foo.co.za
password: 1234
grant_type: password

HTTP 200
[Captures]
access_token: jsonpath "$['access_token']"

SET access_token = {{ access_token }}

Now either one must copy and paste it at the top of all the related hurl files, or there needs to be a way to share the access_token variable between calls, e.g. hurl --variable username=bob login.hurl need_token_here.hurl

Proposal

I have being going through the docs and can't figure out how to, maybe somethings already exists, if not might be great to update the FAQ to help new commers. If no way exists, maybe one could export the variable to the hurl runner which passes them into the next session?

@mangelozzi mangelozzi added the enhancement New feature or request label Nov 1, 2023
@RyanEager-TensorIoT
Copy link

I've been facing this same issue.

A more generic solution would be creating the ability to call a Hurl file within a Hurl file.

users.hurl

hurl auth.hurl --variables-file vars.env
# ^ This would run the file and with captures passed back. 

#Get list of users
GET {{host}}/users
Authorization: Bearer {{cognitoIdToken}}

auth.hurl

# Get Cognito Tokens
POST https://cognito-idp.us-west-2.amazonaws.com/
X-Amz-Target: AWSCognitoIdentityProviderService.InitiateAuth
Content-Type: application/x-amz-json-1.1
{
    "AuthParameters": {
        "USERNAME": "{{username}}",
        "PASSWORD": "{{password}}"
    },
    "AuthFlow": "USER_PASSWORD_AUTH",
    "ClientId": "{{clientId}}"
}

HTTP 200
[Captures]
cognitoAccessToken: jsonpath "$.AuthenticationResult.AccessToken"
cognitoIdToken: jsonpath "$.AuthenticationResult.IdToken"

@SilenLoc
Copy link

SilenLoc commented Nov 27, 2023

I would also like to hurl to implement something like that.

For now I created a tool only for that, https://github.com/SilenLoc/aditus, it only works with Auth0 or equal token endpoints with pw flow. (not everything in the wild is OIDC compliant)

Obvs. you can use pure curl, take the token with jq from the response, then assign it to HURL_access_token={{token}}

I made and will continue to improve the tool to integrate with Hurl. For now it supports creating a env file with = and returning the token raw or the whole answer.

@Taoaozw
Copy link

Taoaozw commented Mar 20, 2024

I've been facing this same issue.我一直面临同样的问题。

A more generic solution would be creating the ability to call a Hurl file within a Hurl file.更通用的解决方案是创建在 Hurl 文件中调用 Hurl 文件的功能。

users.hurl 用户.hurl

hurl auth.hurl --variables-file vars.env
# ^ This would run the file and with captures passed back. 

#Get list of users
GET {{host}}/users
Authorization: Bearer {{cognitoIdToken}}

auth.hurl 授权文件

# Get Cognito Tokens
POST https://cognito-idp.us-west-2.amazonaws.com/
X-Amz-Target: AWSCognitoIdentityProviderService.InitiateAuth
Content-Type: application/x-amz-json-1.1
{
    "AuthParameters": {
        "USERNAME": "{{username}}",
        "PASSWORD": "{{password}}"
    },
    "AuthFlow": "USER_PASSWORD_AUTH",
    "ClientId": "{{clientId}}"
}

HTTP 200
[Captures]
cognitoAccessToken: jsonpath "$.AuthenticationResult.AccessToken"
cognitoIdToken: jsonpath "$.AuthenticationResult.IdToken"

I think it's great.

@danbrotherston
Copy link

This seems like a natural use case for the intended purpose of this tool, and the flow described of including files is a reasonable method of composition. But either way, definitely need some support for this login workflow in order to use this tool.

@dompie
Copy link

dompie commented Apr 4, 2024

I was looking for a way to test different tokens for different request parameters. I could reuse variables in the following way. Hope it helps:

token.hurl

GET {{host}}/api/get/token/for/abcdef12345
HTTP 200

[Captures]
token: jsonpath "$.data.token"

[Asserts]
jsonpath "$.data.token" matches "^[a-zA-Z0-9]{10}csrf$"


GET {{host}}/api/get/token/for/abc123
HTTP 200
[Asserts]
jsonpath "$.data.token" not matches "{{token}}"

@lu-zero
Copy link

lu-zero commented Dec 12, 2024

I suggest to add a [Include] in the shape of

[Include]
path: "some/path/relative/to/the/hurl/file"

That would be resolved so that every place with that pastes the pointed file inside.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request topic: import
Projects
None yet
Development

Successfully merging a pull request may close this issue.

8 participants