diff options
| author | dequis <dx@dxzone.com.ar> | 2017-10-16 22:11:42 -0300 | 
|---|---|---|
| committer | dequis <dx@dxzone.com.ar> | 2017-10-16 22:11:42 -0300 | 
| commit | 24db488909604dd389b584c1f1ce43c549648dbe (patch) | |
| tree | cd5bb0df1a81a8ed370540c800eb13bbb5051f3a /facebook/facebook-api.h | |
| parent | 1e264442a48f33a5933c49a2c0332e426dcdb4a1 (diff) | |
| download | bitlbee-facebook-24db488909604dd389b584c1f1ce43c549648dbe.tar.gz bitlbee-facebook-24db488909604dd389b584c1f1ce43c549648dbe.tar.bz2 bitlbee-facebook-24db488909604dd389b584c1f1ce43c549648dbe.tar.xz | |
Work chat login support (enable the "work" setting to use it)
This covers three autodetected login types:
1. Work account password
   Simple, very similar to normal account types
2. Linked personal account
   This is deprecated but still needed in some companies. Looks just
   like password auth to users. In rare cases there may be more than
   one work account linked to a personal account, in which case this
   will only use the first one. Usually they can be de-linked by
   assigning a password (see the official docs)
3. SSO
   This one is awkward. The password can be set to garbage and users
   will receive a PM with instructions to do an oauth-like login,
   but there's no explicit auth code screen, just a redirect to a
   fb-workchat-sso://, which probably results in an error. Users are
   expected to copy that url, hopefully from the address bar.
   Not very practical, but works!
In all cases, the username is the work account email.
Diffstat (limited to 'facebook/facebook-api.h')
| -rw-r--r-- | facebook/facebook-api.h | 80 | 
1 files changed, 79 insertions, 1 deletions
| diff --git a/facebook/facebook-api.h b/facebook/facebook-api.h index 621800f..2e63471 100644 --- a/facebook/facebook-api.h +++ b/facebook/facebook-api.h @@ -89,6 +89,20 @@  #define FB_API_SECRET  "374e60f8b9bb6b8cbb30f78030438895"  /** + * FB_WORK_API_KEY: + * + * The Facebook workchat app API key. + */ +#define FB_WORK_API_KEY  "312713275593566" + +/** + * FB_WORK_API_SECRET: + * + * The Facebook workchat app API secret. + */ +#define FB_WORK_API_SECRET  "d2901dc6cb685df3b074b30b56b78d28" + +/**   * FB_ORCA_AGENT   *   * The part of the user agent that looks like the official client, since the @@ -138,6 +152,15 @@  #define FB_API_URL_AUTH  FB_API_BHOST "/method/auth.login"  /** + * FB_API_URL_WORK_PRELOGIN + * + * The URL for workchat pre-login information, indicating what auth method + * should be used + */ + +#define FB_API_URL_WORK_PRELOGIN  FB_API_GHOST "/at_work/pre_login_info" + +/**   * FB_API_URL_GQL:   *   * The URL for GraphQL requests. @@ -173,6 +196,14 @@  #define FB_API_URL_TOPIC  FB_API_AHOST "/method/messaging.setthreadname"  /** + * FB_API_SSO_URL: + * + * Template for the URL shown to workchat users when trying to authenticate + * with SSO. + */ +#define FB_API_SSO_URL "https://m.facebook.com/work/sso/mobile?app_id=312713275593566&response_url=fb-workchat-sso%%3A%%2F%%2Fsso&request_id=%s&code_challenge=%s&email=%s" + +/**   * FB_API_QUERY_CONTACT:   *   * The query hash for the `UsersQuery`. @@ -320,6 +351,16 @@  #define FB_API_QUERY_XMA  10153919431161729  /** + * FB_API_WORK_COMMUNITY_PEEK: + * + * The docid with information about the work community of the currently + * authenticated user. + * + * Used when prelogin returns can_login_via_linked_account + */ +#define FB_API_WORK_COMMUNITY_PEEK 1295334753880530 + +/**   * FB_API_CONTACTS_COUNT:   *   * The maximum amount of contacts to fetch in a single request. If this @@ -674,12 +715,49 @@ fb_api_error_emit(FbApi *api, GError *error);   * @api: The #FbApi.   * @user: The Facebook user name, email, or phone number.   * @pass: The Facebook password. + * @credentials_type: Type of work account credentials, or NULL   *   * Sends an authentication request to Facebook. This will obtain   * session information, which is required for all other requests.   */  void -fb_api_auth(FbApi *api, const gchar *user, const gchar *pass); +fb_api_auth(FbApi *api, const gchar *user, const gchar *pass, const gchar *credentials_type); + +/** + * fb_api_work_login: + * @api: The #FbApi. + * @user: The Facebook user name, email, or phone number. + * @pass: The Facebook password. + * + * Starts the workchat login sequence. + */ +void +fb_api_work_login(FbApi *api, gchar *user, gchar *pass); + +/** + * fb_api_work_gen_sso_url: + * @api: The #FbApi. + * @user: The Facebook user email. + * + * Generates the URL to be shown to the user to get the SSO auth token. This + * url contains a challenge and the corresponding verifier is saved in the + * FbApi instance to be used later. + * + * Returns: a newly allocated string. + */ +gchar * +fb_api_work_gen_sso_url(FbApi *api, const gchar *user); + +/** + * fb_api_work_got_nonce: + * @api: The #FbApi. + * @url: The fb-workchat-sso:// URL as entered by the user + * + * Parses the fb-workchat-sso:// URL that the user got redirected to and + * continues with work_sso_nonce auth + */ +void +fb_api_work_got_nonce(FbApi *api, const gchar *url);  /**   * fb_api_contact: | 
