[Solved ✅] Using custom Client id and Client Secret. But what should the callback url be?
I need to whitelist the correct callback URL but what is the correct URL, I cannot find the docs
39 Replies
unwilling-turquoise•6mo ago
Hey @pinkponk, are you using triggers??
genetic-orangeOP•6mo ago
No not yet. I’m just setting things up to try this instead of my own auth flows for my saas app but i cant have composio logo on the consent screens. I want to use my own ”application” but when i need to tell for example google which callback url is safe for my application auth flow
unwilling-turquoise•6mo ago
You can add this
data:image/s3,"s3://crabby-images/85b3b/85b3ba153a7285d64b54ccbc0e3bf6d0afcba3cb" alt="No description"
unwilling-turquoise•6mo ago
Lemme know if it works for you 🙌
genetic-orangeOP•6mo ago
tried it on Google but just get
Access blocked: This app’s request is invalid
Error 400: redirect_uri_mismatch
Don't know if I have done something wrong. I didn't spend too much time on this. I tried adding composio.dev as an authorized domain.
But is the idea of composio that this should be possible. I mean for SAAS developers to handle their users and for me to be able to use my own client_id etc just as long as I add the Authorised redirect urls?unwilling-turquoise•6mo ago
Can't get your question. Other than that we provide integrations for that.
genetic-orangeOP•6mo ago
What I'm trying to do is to for instance add Google integration but use my own Client_id and client_secret, see image 1
I then try to add an account, image 2.
But then I get from google, image 3. clicking error details says
Error 400: redirect_uri_mismatch
Request details: flowName=GeneralOAuthFlow
I tried adding composio.dev as a trusted domain for my application in cloud console on google as I thought I needed to tell google to trust composio.dev when it redirects which is why I asked my original question. I tried adding it but still the same error., see image 4.
So my new question is, where are the docs for this? and should this be possible? I mean I want my logo to be shown on the consent screen and not composio.data:image/s3,"s3://crabby-images/41327/4132742197454b7a8ca12f280995f4e64ea7dbc3" alt="No description"
data:image/s3,"s3://crabby-images/1a35c/1a35c36f0a09cc1f5578c2228f61eed04b4af9e7" alt="No description"
data:image/s3,"s3://crabby-images/ee025/ee0253f3cd13ad01d986b881533774f450052c16" alt="No description"
data:image/s3,"s3://crabby-images/f6c32/f6c32325590f55cc7415d9acf5dc63da93ee8126" alt="No description"
unwilling-turquoise•6mo ago
Have you added this in redirect URIs??
Rest I am confirming regarding your question
Add the 3rd one and it will work
genetic-orangeOP•6mo ago
omfg so sorry, I had added this to the wrong application which had the same name... and which weren't a "web application" but a "desktop application" .
It now "works" but it still says composio.dev "to continue to composio.dev" see images
So again why can't I get my own logo and name instead of composio?
data:image/s3,"s3://crabby-images/97514/975144653e35e6b7874540d33afeb078332d1d3a" alt="No description"
data:image/s3,"s3://crabby-images/6d9fa/6d9fa9ebad733aa5cbaabce2abcc77db411b8db8" alt="No description"
fair-rose•6mo ago
hey - you will need to use your own oauth2.0 credentials to get your own own logo and name, which you can get from your google cloud console.
Here's you can do it: https://support.google.com/cloud/answer/6158849?hl=en#zippy=
Before creating the OAuth 2.0 credentials, you need to enable the Google Drive APIs and then select the relevant scopes while creating OAuth 2.0 credentials.
However, your users will see "Not Verified" on this OAuth page as you need to get your OAuth 2.0 app verified and might need to go through the CASA Tier 2 assessment for restricted scopes.
Setting up OAuth 2.0 - Google Cloud Platform Console Help
To use OAuth 2.0 in your application, you need an OAuth 2.0 client ID, which your application uses when requesting an OAuth 2.0 access token. To create an OAuth 2.0 client
genetic-orangeOP•6mo ago
Yes I'm using my own cliend_id and client_secret but I still don't get my own logo. When running my own setup I do get my own logo but when I try use the same client_id with composio is just says composio.dev. I can see in the url that composio redirects with the same client_id I use for my other setup which has my logo.
fair-rose•6mo ago
This is weird. Can you confirm if you setup Client Id and Secret when creating the integration as shown in the attached video?
genetic-orangeOP•6mo ago
I confirm that I did what you did in the video and here are some screenshots showing that I indeed use my own client_id. I removed the cliend_secret for obvs reasons
data:image/s3,"s3://crabby-images/1a252/1a252884fef95cb44ed82ef2eb1d3ad5a67af5d7" alt="No description"
data:image/s3,"s3://crabby-images/07124/07124c7ce46b5f69b046b908f86a29311bbb7486" alt="No description"
data:image/s3,"s3://crabby-images/671e3/671e3bfe84071494902fa9854c612f3fd129a10f" alt="No description"
data:image/s3,"s3://crabby-images/20b91/20b917833d82fb66657e562b35ed93cd4f62e3e6" alt="No description"
data:image/s3,"s3://crabby-images/f8d44/f8d4453fec9d9b1b379bbf6d1dabb88f3436150c" alt="No description"
data:image/s3,"s3://crabby-images/200eb/200eb9f40dd5014b3c17a66f263802ee12fce91f" alt="No description"
genetic-orangeOP•6mo ago
All I know is that when I run this with my own auth tools I get the correct consent screen with my logo
fair-rose•6mo ago
Yup - Everything is perfect. Let me try this on my end.
I just verified this - this is working perfectly - do you want to get on a quick call to sort this out right now?
genetic-orangeOP•6mo ago
saw this a bit late. had to leave. I'd be happy to jump on a call but I guess I don't know when you are available.
Good to know that it should work and that it works for you. Maybe there is some cache of some sort making this not work out.
genetic-orangeOP•6mo ago
btw what do you see when going to this link:
https://accounts.google.com/o/oauth2/v2/auth/oauthchooseaccount?client_id=983117019209-781tqekgd9d2d95p1jju74v3jqe61iaa.apps.googleusercontent.com&redirect_uri=https%3A%2F%2Fbackend.composio.dev%2Fapi%2Fv1%2Fauth-apps%2Fadd&scope=https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fdrive.file%20https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fuserinfo.email&response_type=code&access_type=offline&prompt=consent&state=production_eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJjb25uZWN0aW9uSWQiOiI2NjhlNmUwYy04MWI3LTQ1ODgtOTRlZC1hZjQ1Y2NlOWY5MjkiLCJpbnRlZ3JhdGlvbklkIjoiYzEyMjUwMGUtMGI2Yi00ZjE4LWE3YzEtY2JjYWNhNTBhMzllIiwiYXBwTmFtZSI6Imdvb2dsZWRyaXZlIiwiY2xpZW50SW5mbyI6eyJjbGllbnRJZCI6IjE2NzYyNDI5LWQ1NWUtNGIyNC05MjcxLWYxNDgxODhlMzk3MCJ9LCJpYXQiOjE3MjY1NjEzMDZ9.r2MCCZzc7FibOhLilxOFT0l1sutdHyBxfcZPrjFVwhg&code_challenge=HQ557LOaXtFaYsXQT9TE2LAJdGZG1T-r2Oqah5xHHCs&code_challenge_method=S256&service=lso&o2v=2&ddm=0&flowName=GeneralOAuthFlow
Do you see composio.dev or vorker.ai? You probably won't see this in time and so the flow will time out but give me a ping so I can send you a new link
fair-rose•6mo ago
I still see composio.dev - can you confirm if this is your client id:
983117019209-781tqekgd9d2d95p1jju74v3jqe61iaa.apps.googleusercontent.com
?genetic-orangeOP•6mo ago
from google> so yes it is the same
data:image/s3,"s3://crabby-images/ae40a/ae40a34f75abffd5352d62be06e35c8542b5eccc" alt="No description"
fair-rose•6mo ago
i am on #debug-help voice channel - let's chat?
genetic-orangeOP•6mo ago
sure!
fair-rose•6mo ago
hey @pinkponk - can you check your OAuth Consent Screen configuration?
data:image/s3,"s3://crabby-images/330cd/330cd405986d29d84ca8b410ad405a935e1b51fe" alt="No description"
genetic-orangeOP•6mo ago
yeah what should I check for
genetic-orangeOP•6mo ago
Looks like this for ex
data:image/s3,"s3://crabby-images/3b0be/3b0bed2c5ebd5570857cc353ea06db49c7969ed8" alt="No description"
fair-rose•6mo ago
App Information
data:image/s3,"s3://crabby-images/d9afd/d9afd6e94edb45bef5dabbe5f415c883fcac1c82" alt="No description"
fair-rose•6mo ago
looks good.
fair-rose•6mo ago
did you enable the Google Drive API and if yes, can you confirm you have selected the below scope?
data:image/s3,"s3://crabby-images/f6db6/f6db614df585b3cc4e1df3bdc8183d23536da74a" alt="No description"
genetic-orangeOP•6mo ago
data:image/s3,"s3://crabby-images/42143/42143f289124496ea0bf26470e43c0ea843a92b2" alt="No description"
genetic-orangeOP•6mo ago
data:image/s3,"s3://crabby-images/984b7/984b739fe600be39966c7283c74358c1dac03aec" alt="No description"
genetic-orangeOP•6mo ago
I have run this client_id on my own servers and it looks good, gets me access etc
fair-rose•6mo ago
oh okay - can you check the scope that you setup in the Integration settings on Composio dashboard?
genetic-orangeOP•6mo ago
"https://www.googleapis.com/auth/drive.file,https://www.googleapis.com/auth/userinfo.email"
I mean I didn't modify the scopes on composio. Just added the google drive tool
fair-rose•6mo ago
got it. can you share your email that is associated with your composio account?
genetic-orangeOP•6mo ago
send it in a DM
fair-rose•6mo ago
got it.
rising-crimson•2mo ago
I am having this same issue - everything is configured correctly on my Composio dashboard (trying to connect Gmail to custom OAuth app in order to surface my custom branding), and I used my own Google OAuth client ID and secret at time of integration creation, yet I'm still seeing Composio branding language on the OAuth consent screen. Was there ever a resolution to this issue that you found @Karthikeya @pinkponk ? Sorry to resurrect the old thread here, thanks in advance for the help.
eastern-cyan•2mo ago
Google only allows for one app logo per callback URL. Very google specific check.
So the only way to go about it is a bit tedious - You have to setup a proxy at your domain and receive the callback and forward it to our callback URL https://backend.composio.dev/api/v1/auth-apps/add.
You need to set your callback URL while passing client id and secret in Composio app in the Redirect URI field.
rising-crimson•2mo ago
@kaavee ahhh, that makes sense. really appreciate the follow-up, thank you!
genetic-orangeOP•2mo ago
btw @joeyv I added this to my nginx, worked like a charm>
now i reverse proxy using my own domain