summaryrefslogtreecommitdiff
path: root/alpine/imap.c
diff options
context:
space:
mode:
Diffstat (limited to 'alpine/imap.c')
-rw-r--r--alpine/imap.c204
1 files changed, 1 insertions, 203 deletions
diff --git a/alpine/imap.c b/alpine/imap.c
index 887c56e..91f87b1 100644
--- a/alpine/imap.c
+++ b/alpine/imap.c
@@ -135,209 +135,7 @@ int init_wincred_funcs(void);
static char *details_cert, *details_host, *details_reason;
extern XOAUTH2_INFO_S xoauth_default[];
-
-/*
- * This is the private information of the client, which is passed to
- * c-client for processing. Every c-client application must have its
- * own.
- */
-OAUTH2_S alpine_oauth2_list[] = {
- {GMAIL_NAME,
- {"imap.gmail.com", "smtp.gmail.com", NULL, NULL},
- {{"client_id", NULL},
- {"client_secret", NULL},
- {"tenant", NULL}, /* not used */
- {"code", NULL}, /* access code from the authorization process */
- {"refresh_token", NULL},
- {"scope", "https://mail.google.com/"},
- {"redirect_uri", "urn:ietf:wg:oauth:2.0:oob"},
- {"grant_type", "authorization_code"},
- {"grant_type", "refresh_token"},
- {"response_type", "code"},
- {"state", NULL},
- {"device_code", NULL} /* not used */
- },
- {{"GET", (unsigned char *) "https://accounts.google.com/o/oauth2/auth", /* authorization address, get access code */
- {OA2_Id, OA2_Scope, OA2_Redirect, OA2_Response, OA2_End, OA2_End, OA2_End}},
- {NULL, NULL, {OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}}, /* Device Info information, not used */
- {"POST", (unsigned char *) "https://accounts.google.com/o/oauth2/token", /* Address to get refresh token from access code */
- {OA2_Id, OA2_Secret, OA2_Redirect, OA2_GrantTypeforAccessToken, OA2_Code, OA2_End, OA2_End}},
- {"POST", (unsigned char *) "https://accounts.google.com/o/oauth2/token", /* access token from refresh token */
- {OA2_Id, OA2_Secret, OA2_RefreshToken, OA2_GrantTypefromRefreshToken, OA2_End, OA2_End, OA2_End}}
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information */
- NULL, /* access token */
- NULL, /* special IMAP ID */
- 0, /* do not hide */
- 0, /* expiration time */
- 0, /* first time indicator */
- 1, /* client secret required */
- 0, /* Cancel refresh token */
- GMAIL_FLAGS /* default flags. For Gmail this should be set to OA2_AUTHORIZE */
- },
- {OUTLOOK_NAME,
- {"outlook.office365.com", "smtp.office365.com", NULL, NULL},
- {{"client_id", NULL},
- {"client_secret", NULL}, /* not used, but needed */
- {"tenant", NULL}, /* used */
- {"code", NULL}, /* not used, not needed */
- {"refresh_token", NULL},
- {"scope", "offline_access https://outlook.office.com/IMAP.AccessAsUser.All https://outlook.office.com/SMTP.Send"},
- {"grant_type", "urn:ietf:params:oauth:grant-type:device_code"},
- {"scope", NULL}, /* not used */
- {"grant_type", "refresh_token"},
- {"response_type", "code"}, /* not used */
- {"state", NULL}, /* not used */
- {"device_code", NULL} /* only used for frst time set up */
- },
- {{NULL, NULL, {OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}}, /* Get Access Code, Not used */
- {"POST", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/devicecode", /* first time use and get device code information */
- {OA2_Id, OA2_Scope, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}},
- {"POST", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/token", /* Get first Refresh Token and Access token */
- {OA2_Id, OA2_Redirect, OA2_DeviceCode, OA2_End, OA2_End, OA2_End, OA2_End}},
- {"POST", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/token", /* Get access token from refresh token */
- {OA2_Id, OA2_RefreshToken, OA2_Scope, OA2_GrantTypefromRefreshToken, OA2_End, OA2_End, OA2_End}}
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information */
- NULL, /* access token */
- NULL, /* special IMAP ID */
- 0, /* do not hide */
- 0, /* expiration time */
- 0, /* first time indicator */
- 0, /* client secret required */
- 0, /* Cancel refresh token */
- OUTLOOK_FLAGS /* default flags. For OUTLOOK this should be set to OA2_DEVICE */
- },
- {OUTLOOK_NAME,
- {"outlook.office365.com", "smtp.office365.com", NULL, NULL},
- {{"client_id", NULL},
- {"client_secret", NULL}, /* not used, but needed */
- {"tenant", NULL}, /* used */
- {"code", NULL}, /* used during authorization */
- {"refresh_token", NULL},
- {"scope", "offline_access https://outlook.office.com/IMAP.AccessAsUser.All https://outlook.office.com/SMTP.Send"},
- {"redirect_uri", "http://localhost"},
- {"grant_type", "authorization_code"},
- {"grant_type", "refresh_token"},
- {"response_type", "code"},
- {"state", NULL}, /* not used */
- {"device_code", NULL} /* not used */
- },
- {{"GET", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/authorize", /* Get Access Code */
- {OA2_Id, OA2_Scope, OA2_Redirect, OA2_Response, OA2_End, OA2_End, OA2_End}},
- {NULL, NULL, {OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}}, /* device code, not used */
- {"POST", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/token", /* Get first Refresh Token and Access token */
- {OA2_Id, OA2_Redirect, OA2_Scope, OA2_GrantTypeforAccessToken, OA2_Secret, OA2_Code, OA2_End}},
- {"POST", (unsigned char *) "https://login.microsoftonline.com/\001/oauth2/v2.0/token", /* Get access token from refresh token */
- {OA2_Id, OA2_RefreshToken, OA2_Scope, OA2_GrantTypefromRefreshToken, OA2_Secret, OA2_End, OA2_End}}
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information, not used */
- NULL, /* access token */
- NULL, /* special IMAP ID */
- 0, /* do not hide */
- 0, /* expiration time */
- 0, /* first time indicator */
- 1, /* client secret required */
- 0, /* Cancel refresh token */
- OUTLOOK_FLAGS /* default flags. For OUTLOOK this should be set to OA2_DEVICE */
- },
- {YAHOO_NAME,
- {"imap.mail.yahoo.com", "smtp.mail.yahoo.com", NULL, NULL},
- {{"client_id", NULL},
- {"client_secret", NULL}, /* used */
- {"tenant", NULL}, /* not used */
- {"code", NULL}, /* used during authorization */
- {"refresh_token", NULL},
- {"scope", NULL}, /* not used! */
- {"redirect_uri", "oob"}, /* https://localhost */
- {"grant_type", "authorization_code"},
- {"grant_type", "refresh_token"},
- {"response_type", "code"},
- {"state", NULL}, /* used */
- {"device_code", NULL} /* not used */
- },
- {{"GET", (unsigned char *) "https://api.login.yahoo.com/oauth2/request_auth", /* Get Access Code */
- {OA2_Id, OA2_Redirect, OA2_Response, OA2_State, OA2_End, OA2_End, OA2_End}},
- {NULL, NULL, {OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}}, /* device code, not used */
- {"POST", (unsigned char *) "https://api.login.yahoo.com/oauth2/get_token", /* Get first Refresh Token and Access token */
- {OA2_Id, OA2_Secret, OA2_Redirect, OA2_Code, OA2_GrantTypeforAccessToken, OA2_End, OA2_End}},
- {"POST", (unsigned char *) "https://api.login.yahoo.com/oauth2/get_token", /* Get access token from refresh token */
- {OA2_Id, OA2_Secret, OA2_Redirect, OA2_RefreshToken, OA2_GrantTypefromRefreshToken, OA2_End, OA2_End}}
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information, not used */
- NULL, /* access token */
- "ALPINE_V1", /* special IMAP ID */
- 1, /* hide */
- 0, /* expiration time */
- 0, /* first time indicator */
- 1, /* client secret required */
- 0, /* Cancel refresh token */
- YAHOO_FLAGS /* default flags. For YAHOO this should be set to OA2_AUTHORIZE */
- },
- {YANDEX_NAME,
- {"imap.yandex.com", "smtp.yandex.com", NULL, NULL},
- {{"client_id", NULL},
- {"client_secret", NULL}, /* not used, but needed */
- {"tenant", NULL}, /* not used */
- {"code", NULL}, /* used during authorization */
- {"refresh_token", NULL},
- {"scope", NULL}, /* not needed, so not used */
- {"redirect_uri", "https://oauth.yandex.ru/verification_code"},
- {"grant_type", "authorization_code"},
- {"grant_type", "refresh_token"},
- {"response_type", "code"},
- {"state", NULL}, /* not used */
- {"device_code", NULL} /* not used */
- },
- {{"GET", (unsigned char *) "https://oauth.yandex.com/authorize", /* Get Access Code */
- {OA2_Id, OA2_Redirect, OA2_Response, OA2_End, OA2_End, OA2_End, OA2_End}},
- {NULL, NULL, {OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End, OA2_End}}, /* device code, not used */
- {"POST", (unsigned char *) "https://oauth.yandex.com/token", /* Get first Refresh Token and Access token */
- {OA2_Id, OA2_Redirect, OA2_GrantTypeforAccessToken, OA2_Secret, OA2_Code, OA2_End, OA2_End}},
- {"POST", (unsigned char *) "https://oauth.yandex.com/token", /* Get access token from refresh token */
- {OA2_Id, OA2_RefreshToken, OA2_GrantTypefromRefreshToken, OA2_Secret, OA2_End, OA2_End, OA2_End}}
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information, not used */
- NULL, /* access token */
- NULL, /* special IMAP ID */
- 0, /* do not hide */
- 0, /* expiration time */
- 0, /* first time indicator */
- 1, /* client secret required */
- 0, /* Cancel refresh token */
- YANDEX_FLAGS /* default flags. For YANDEX this should be set to OA2_AUTHORIZE */
- },
- {NULL, /* Name, unsigned char * */
- {NULL, NULL, NULL, NULL }, /* host and equivalents */
- {{NULL, NULL}, /* client-id */
- {NULL, NULL}, /* client-secret */
- {NULL, NULL}, /* tenant - outlook */
- {NULL, NULL}, /* access_code, for authorize method */
- {NULL, NULL}, /* refresh token */
- {NULL, NULL}, /* scope */
- {NULL, NULL}, /* redirect */
- {NULL, NULL}, /* grant type for access token */
- {NULL, NULL}, /* grant type from refresh token */
- {NULL, NULL}, /* response */
- {NULL, NULL}, /* state */
- {NULL, NULL} /* device code */
- },
- {{NULL, NULL, {0, 0, 0, 0, 0, 0, 0}}, /* method, server, parameters for authorize */
- {NULL, NULL, {0, 0, 0, 0, 0, 0, 0}}, /* method, server, parameters for device login */
- {NULL, NULL, {0, 0, 0, 0, 0, 0, 0}}, /* method, server, parameters for getting refresh token */
- {NULL, NULL, {0, 0, 0, 0, 0, 0, 0}} /* method, server, parameters for refreshing access token */
- },
- {NULL, NULL, NULL, 0, 0, NULL}, /* device_code information */
- NULL, /* access token */
- NULL, /* special IMAP ID */
- 0, /* Hide this */
- 0, /* expiration time */
- 0, /* first time */
- 0, /* require secret */
- 0, /* cancel refresh token */
- 0 /* flags */
- }
-};
+extern OAUTH2_S alpine_oauth2_list[];
int
xoauth2_flow_tool(struct pine *ps, int cmd, CONF_S **cl, unsigned int flags)