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

Consider Login-requirement / authentication to protect TraderX Demo Environment #131

Open
DovOps opened this issue Mar 8, 2024 · 13 comments
Assignees
Labels
enhancement New feature or request help wanted Extra attention is needed

Comments

@DovOps
Copy link
Contributor

DovOps commented Mar 8, 2024

Feature Request

Description of Problem:

Do we want the traderx demo to be 100% open? This may cause bad actors to exploit the unauthenticated tool to inject offensive content, or other things, rather than just demonstrate the functionality.

Potential Considerations:

Does this create a barrier to exploration, or would people be hesitant?
Is this difficult to implement?
Do we want to do this?

@DovOps
Copy link
Contributor Author

DovOps commented Mar 22, 2024

Recommend: Non-default option while doing development, but when deployed as an environment, ingress controller should enforce access control. (any major social+github SSO should be accepted) and logging usage.

Concerns: This stops being 'quick and easy' with a 'paywall-style' login.

@maoo
Copy link
Member

maoo commented Mar 25, 2024

I think that Github SSO would be the best option, in terms of accessibility from FINOS members and community at large.

I share the concern around the paywall-style limitation, though we could only limit input submission (ie add account) to logged users, assuming it's easy to implement.

I suppose that this change would only affect the frontend (specifically angular) component, which is where I lack of expertise; would be great to find someone with Angular experience who could contribute this feature.

@maoo maoo removed their assignment Mar 25, 2024
@maoo maoo added enhancement New feature or request help wanted Extra attention is needed labels Mar 25, 2024
@leandroyabut
Copy link

I think that Github SSO would be the best option, in terms of accessibility from FINOS members and community at large.

I share the concern around the paywall-style limitation, though we could only limit input submission (ie add account) to logged users, assuming it's easy to implement.

I suppose that this change would only affect the frontend (specifically angular) component, which is where I lack of expertise; would be great to find someone with Angular experience who could contribute this feature.

I have Angular experience so I would be happy to take a look at this issue. Github SSO should be fairly easy to implement in Angular.

@maoo
Copy link
Member

maoo commented Apr 26, 2024

Thanks for volunteering @leandroyabut ! I've assigned the issue to you; happy to test and review, when the PR is avaiable.

@leandroyabut
Copy link

No problem, @maoo ! However, I do need some assistance with setting up our GitHub authentication flow. We need to set up OAuth2.0 using an initial GitHub account. I assume we should use this project's primary GitHub account to set it up.

https://docs.github.com/en/apps/oauth-apps/building-oauth-apps/creating-an-oauth-app

Afterwards, we need to securely store the client ID and the client secret.

I'm wondering if this part needs to be its own issue. What do you think?

@maoo
Copy link
Member

maoo commented Apr 30, 2024

Hi @leandroyabut !

I created the Oauth App as follows, let me know if you want me to change the callback URL.

Screenshot 2024-05-01 at 00 11 00

Then I've set CLIENT_ID and CLIENT_SECRET as GitHub Action secrets for now, though we'd probably want to have them securely stored into the (Docker Compose) Demo environment; I'll take care of it when we're ready to go live.

In the meantime, I could send them to you via (FINOS) Slack; ping me on help@finos.org and I'll invite you.

Thank you!

@leandroyabut
Copy link

Hi everyone, as far as the flow, will we just redirect unauthenticated users to a login page (e.g. /login route)?

@maoo
Copy link
Member

maoo commented May 14, 2024

@leandroyabut - I'd say so. @DovOps wdyt?

@leandroyabut
Copy link

@maoo Can you make another application with the callback URL and homepage URL as our localhost addresses. http://localhost:18093

@maoo
Copy link
Member

maoo commented May 23, 2024

@maoo Can you make another application with the callback URL and homepage URL as our localhost addresses. http://localhost:18093

Here it comes! 😄

Screenshot 2024-05-23 at 11 29 23

Sending now id and secret via Slack. Let me know if something is missing. TY!

@leandroyabut
Copy link

After some testing with this, it seems that Github doesn't allow us to make a POST Request to their access_token endpoint due to CORS. The solution is to create some sort of endpoint on our back end to make this request for us that our front-end can use to both send the auth code received from Github and then receive the access token from that same endpoint as a response.

Attempted flow:

  1. Get auth code from Github - SUCCESS
  2. Send auth code along with client ID, client secret, and redirect URL as a POST request to access_token endpoint. - FAILED due to CORS.

Proposed flow:

  1. Get auth code from Github - SUCCESS
  2. Send auth code to backend endpoint - ...
  3. Backend sends POST request to Github access_token endpoint. - ...
  4. Receive response with the access_token and send back to frontend - ...

We need someone to implement this endpoint in a separate auth microservice. What do you guys think?

@maoo
Copy link
Member

maoo commented Jun 21, 2024

Hi @leandroyabut - we already stumbled into CORS issues, which led us to add an ingress module in https://github.com/finos/traderX/tree/main/ingress . Is this something that could help you?

@tarekquao
Copy link

Did this issue already get completed?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

4 participants