You are here

hybridauth.admin.inc in HybridAuth Social Login 6.2

Same filename and directory in other branches
  1. 7.2 hybridauth.admin.inc
  2. 7 hybridauth.admin.inc

Administrative pages forms and functions for the HybridAuth module.

File

hybridauth.admin.inc
View source
<?php

/**
 * @file
 * Administrative pages forms and functions for the HybridAuth module.
 */
function hybridauth_admin_settings() {
  if (!variable_get('hybridauth_register', 0) && variable_get('user_register', 1) == 0) {
    drupal_set_message(t('Currently only administrators can create new user accounts. Either change the "Who can register accounts?" option under "Account settings" tab or at the core <a href="!link">Account settings</a>.', array(
      '!link' => url('admin/config/people/accounts'),
    )), 'warning');
  }
  $form = array();
  $form['fset_providers'] = array(
    '#type' => 'fieldset',
    '#title' => t('Authentication providers'),
    '#collapsible' => TRUE,
    '#collapsed' => TRUE,
    '#theme' => 'hybridauth_admin_settings_providers_table',
    '#group' => 'fset_providers',
    '#attached' => array(
      'js' => array(
        'vertical-tabs' => drupal_get_path('module', 'hybridauth') . '/js/hybridauth.admin.js',
      ),
    ),
  );
  foreach (hybridauth_providers_list() as $provider_id => $provider_name) {
    $form['fset_providers'][$provider_id]['icon'] = array(
      '#value' => theme('hybridauth_provider_icon', 'hybridauth_16', $provider_id),
    );
    $form['fset_providers'][$provider_id]['hybridauth_provider_' . $provider_id . '_enabled'] = array(
      '#type' => 'checkbox',
      '#title' => $provider_name,
      '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_enabled', 0),
    );
    $form['fset_providers'][$provider_id]['file'] = array(
      '#value' => array_key_exists($provider_id, hybridauth_providers_files()) ? t('Yes') : t('No'),
    );
    $form['fset_providers'][$provider_id]['hybridauth_provider_' . $provider_id . '_weight'] = array(
      '#type' => 'weight',
      //'#title' => t('Weight'),
      '#delta' => 20,
      '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_weight', 0),
      '#attributes' => array(
        'class' => 'hybridauth-provider-weight',
      ),
    );
    $form['fset_providers'][$provider_id]['settings'] = array(
      '#value' => l(t('Settings'), 'admin/user/hybridauth/provider/' . $provider_id, array(
        'query' => drupal_get_destination(),
      )),
    );
  }
  $form['fset_fields'] = array(
    '#type' => 'fieldset',
    '#title' => t('Required information'),
    '#collapsible' => TRUE,
    '#collapsed' => TRUE,
    '#group' => 'fset_fields',
  );
  $form['fset_fields']['hybridauth_required_fields'] = array(
    '#type' => 'checkboxes',
    '#title' => t('Required information'),
    '#options' => array(
      'email' => t('Email address'),
      'firstName' => t('First name'),
      'lastName' => t('Last name'),
      'gender' => t('Gender'),
    ),
    '#description' => t("Select required information. If authentication provider doesn't return it, visitor will need to fill additional form before registration."),
    '#default_value' => variable_get('hybridauth_required_fields', array(
      'email' => 'email',
    )),
  );
  $form['fset_widget'] = array(
    '#type' => 'fieldset',
    '#title' => t('Widget settings'),
    '#collapsible' => TRUE,
    '#collapsed' => TRUE,
    '#group' => 'fset_widget',
  );
  $options = array(
    'popup' => t('Use a new popup window'),
    'current' => t('Use the current window'),
  );
  $form['fset_widget']['hybridauth_window_type'] = array(
    '#type' => 'radios',
    '#title' => t('Authentication window type'),
    '#options' => $options,
    '#default_value' => variable_get('hybridauth_window_type', 'popup'),
  );
  $form['fset_widget']['hybridauth_widget_title'] = array(
    '#type' => 'textfield',
    '#title' => t('Widget title'),
    '#default_value' => variable_get('hybridauth_widget_title', 'Or log in with...'),
  );
  $options = array(
    'list' => t('Enabled providers icons'),
    'button' => t('Single icon leading to a list of enabled providers'),
    'link' => t('Link leading to a list of enabled providers'),
  );
  $form['fset_widget']['hybridauth_widget_type'] = array(
    '#type' => 'radios',
    '#title' => t('Widget type'),
    '#options' => $options,
    '#default_value' => variable_get('hybridauth_widget_type', 'list'),
  );
  $form['fset_widget']['hybridauth_widget_use_overlay'] = array(
    '#type' => 'checkbox',
    '#title' => t('Display list of enabled providers in an overlay'),
    '#default_value' => variable_get('hybridauth_widget_use_overlay', 1),
  );
  $form['fset_widget']['hybridauth_widget_link_text'] = array(
    '#type' => 'textfield',
    '#title' => t('Link text'),
    '#default_value' => variable_get('hybridauth_widget_link_text', 'Social network account'),
  );
  $form['fset_widget']['hybridauth_widget_link_title'] = array(
    '#type' => 'textfield',
    '#title' => t('Link or icon title'),
    '#default_value' => variable_get('hybridauth_widget_link_title', 'Social network account'),
  );
  $options = array();
  foreach (hybridauth_get_icon_packs() as $name => $icon_pack) {
    $options[$name] = $icon_pack['title'];
  }
  $form['fset_widget']['hybridauth_widget_icon_pack'] = array(
    '#type' => 'select',
    '#title' => t('Icon package'),
    '#options' => $options,
    '#default_value' => variable_get('hybridauth_widget_icon_pack', 'hybridauth_32'),
  );
  $form['fset_widget']['hybridauth_widget_weight'] = array(
    '#type' => 'weight',
    '#title' => t('Widget weight'),
    '#delta' => 100,
    '#description' => t('Determines the order of the elements on the form - heavier elements get positioned later.'),
    '#default_value' => variable_get('hybridauth_widget_weight', 100),
  );
  $form['fset_widget']['hybridauth_widget_hide_links'] = array(
    '#type' => 'checkbox',
    '#title' => t('Hide links'),
    '#description' => t('Remove href property from authentication provider links.'),
    '#default_value' => variable_get('hybridauth_widget_hide_links', 0),
  );
  $form['fset_account'] = array(
    '#type' => 'fieldset',
    '#title' => t('Account settings'),
    '#collapsible' => TRUE,
    '#collapsed' => TRUE,
    '#group' => 'fset_account',
  );
  $core_settings = array(
    0 => t('Only site administrators can create new user accounts.'),
    1 => t('Visitors can create accounts and no administrator approval is required.'),
    2 => t('Visitors can create accounts but administrator approval is required.'),
  );
  $form['fset_account']['hybridauth_register'] = array(
    '#type' => 'radios',
    '#title' => t('Who can register accounts?'),
    '#options' => array(
      0 => t('Follow core') . ': ' . $core_settings[variable_get('user_register', 1)],
      1 => t('Visitors'),
      2 => t('Visitors, but administrator approval is required'),
    ),
    '#description' => t('Select who can register accounts through HybridAuth.') . ' ' . t('The core settings are available at <a href="!link">User settings</a>.', array(
      '!link' => url('admin/user/settings'),
    )),
    '#default_value' => variable_get('hybridauth_register', 0),
  );
  $core_settings = array(
    0 => t("Don't require e-mail verification"),
    1 => t('Require e-mail verification'),
  );
  $form['fset_account']['hybridauth_email_verification'] = array(
    '#type' => 'radios',
    '#title' => t('E-mail verification'),
    '#options' => array(
      0 => t('Follow core') . ': ' . $core_settings[variable_get('user_email_verification', TRUE)],
      1 => t('Require e-mail verification'),
      2 => t("Don't require e-mail verification"),
    ),
    '#description' => t('Select how to handle not verified e-mail addresses (authentication provider gives non-verified e-mail address).') . ' ' . t('The core settings are available at <a href="!link">User settings</a>.', array(
      '!link' => url('admin/user/settings'),
    )),
    '#default_value' => variable_get('hybridauth_email_verification', 0),
  );
  $form['fset_account']['hybridauth_pictures'] = array(
    '#type' => 'checkbox',
    '#title' => t('Save HybridAuth provided picture as user picture'),
    '#description' => t('Save pictures provided by HybridAuth as user pictures. Check the "Enable user pictures" option at <a href="!link">User settings</a> to make this option available.', array(
      '!link' => url('admin/user/settings'),
    )),
    '#default_value' => variable_get('hybridauth_pictures', 1),
    '#disabled' => !variable_get('user_pictures', 0),
  );
  $form['fset_account']['hybridauth_username'] = array(
    '#type' => 'textfield',
    '#title' => t('Username pattern'),
    '#default_value' => variable_get('hybridauth_username', '[firstName] [lastName]'),
    '#description' => t('Create username for new users using this pattern; counter will be added in case of username conflict.') . ' ' . t('You should use only HybridAuth tokens here as the user is not created yet.') . ' ' . t('Install !link module to get list of all available tokens.', array(
      '!link' => l(t('Token'), 'http://drupal.org/project/token', array(
        'attributes' => array(
          'target' => '_blank',
        ),
      )),
    )),
    '#required' => TRUE,
  );
  if (module_exists('token')) {
    $form['fset_account']['fset_token_username'] = array(
      '#type' => 'fieldset',
      '#title' => t('Replacement patterns'),
      '#collapsible' => TRUE,
      '#collapsed' => TRUE,
    );
    $form['fset_account']['fset_token_username']['hybridauth_token_tree'] = array(
      '#value' => theme('token_tree', array(
        'hybridauth',
      ), FALSE),
    );
  }
  $form['fset_account']['hybridauth_registration_username_change'] = array(
    '#type' => 'checkbox',
    '#title' => t('Allow username change when registering'),
    '#description' => t('Allow users to change their username when registering through HybridAuth.'),
    '#default_value' => variable_get('hybridauth_registration_username_change', 0),
  );

  /*$form['fset_account']['hybridauth_display_name'] = array(
      '#type' => 'textfield',
      '#title' => t('Display name pattern'),
      '#default_value' => variable_get('hybridauth_display_name', '[hybridauth_firstName] [hybridauth_lastName]'),
      '#description' => t('You can use any user tokens here.') . ' '
        . t('Install !link module to get list of all available tokens.',
          array('!link' => l(t('Token'), 'http://drupal.org/project/token', array('attributes' => array('target' => '_blank'))))),
      '#required' => TRUE,
    );
    if (module_exists('token')) {
      $form['fset_account']['fset_token_display_name'] = array(
        '#type' => 'fieldset',
        '#title' => t('Replacement patterns'),
        '#collapsible' => TRUE,
        '#collapsed' => TRUE,
      );
      $form['fset_account']['fset_token_display_name']['hybridauth_token_tree'] = array(
        '#value' => theme('token_tree', array('user'), FALSE),
      );
    }*/

  /*$form['fset_account']['hybridauth_override_realname'] = array(
      '#type' => 'checkbox',
      '#title' => t('Override Real name'),
      '#description' => t('Override <a href="!link1">Real name settings</a> using the above display name pattern for users created by HybridAuth. This option is available only if !link2 module is installed.',
        array('!link1' => url('admin/config/people/realname'),
          '!link2' => l(t('Real name'), 'http://drupal.org/project/realname', array('attributes' => array('target' => '_blank'))))),
      '#default_value' => variable_get('hybridauth_override_realname', 0),
      '#disabled' => !module_exists('realname'),
    );*/
  $form['fset_account']['hybridauth_disable_username_change'] = array(
    '#type' => 'checkbox',
    '#title' => t('Disable username change'),
    '#description' => t('Remove username field from user account edit form for users created by HybridAuth.' . ' If this is unchecked then users should also have "Change own username" permission to actually be able to change the username.'),
    '#default_value' => variable_get('hybridauth_disable_username_change', 1),
  );
  $form['fset_account']['hybridauth_remove_password_fields'] = array(
    '#type' => 'checkbox',
    '#title' => t('Remove password fields'),
    '#description' => t('Remove password fields from user account edit form for users created by HybridAuth.'),
    '#default_value' => variable_get('hybridauth_remove_password_fields', 1),
  );
  $form['fset_other'] = array(
    '#type' => 'fieldset',
    '#title' => t('Other settings'),
    '#collapsible' => TRUE,
    '#collapsed' => TRUE,
    '#group' => 'fset_other',
  );
  $form['fset_other']['hybridauth_destination'] = array(
    '#type' => 'textfield',
    '#title' => t('Redirect after login'),
    '#default_value' => variable_get('hybridauth_destination', ''),
    '#description' => t('Drupal path to redirect to, like "node/1". Leave empty to return to the same page.') . ' ' . t('You can use any user or global tokens here.') . ' ' . t('Install !link module to get list of all available tokens.', array(
      '!link' => l(t('Token'), 'http://drupal.org/project/token', array(
        'attributes' => array(
          'target' => '_blank',
        ),
      )),
    )),
  );
  if (module_exists('token')) {
    $form['fset_other']['fset_token'] = array(
      '#type' => 'fieldset',
      '#title' => t('Replacement patterns'),
      '#collapsible' => TRUE,
      '#collapsed' => TRUE,
    );
    $form['fset_other']['fset_token']['hybridauth_token_tree'] = array(
      '#value' => theme('token_tree', array(
        'user',
      ), TRUE),
    );
  }
  $form['fset_other']['hybridauth_forms'] = array(
    '#type' => 'checkboxes',
    '#title' => t('Drupal forms'),
    '#options' => array(
      'user_login' => t('User login form'),
      'user_login_block' => t('User login block'),
      'user_register' => t('User registration form'),
      'comment_form' => t('Comment form'),
    ),
    '#description' => t('Add default HybridAuth widget to these forms.'),
    '#default_value' => variable_get('hybridauth_forms', array(
      'user_login',
      'user_login_block',
    )),
  );
  $form['fset_other']['hybridauth_duplicate_emails'] = array(
    '#type' => 'radios',
    '#title' => t('Duplicate emails'),
    '#options' => array(
      0 => t('Allow duplicate email addresses, create new user account and login'),
      1 => t("Don't allow duplicate email addresses, block registration and advise to login using the existing account"),
      2 => t("Don't allow duplicate email addresses, add new identity to the existing account and login"),
    ),
    '#default_value' => variable_get('hybridauth_duplicate_emails', 1),
    '#description' => t('Select how to handle duplicate email addresses. This situation occurs when the same user is trying to authenticate using different authentication providers, but with the same email address.'),
  );
  $form['fset_other']['hybridauth_debug'] = array(
    '#type' => 'checkbox',
    '#title' => t('Debug mode'),
    '#description' => t('When in debug mode, extra error information will be logged/displayed. This should be disabled when not in development.'),
    '#default_value' => variable_get('hybridauth_debug', FALSE),
  );

  // Add vertical tabs display if available.
  $form['#pre_render'][] = 'vertical_tabs_form_pre_render';
  return system_settings_form($form);
}

/**
 * Theme function for hybridauth_admin_settings() to render providers table.
 */
function theme_hybridauth_admin_settings_providers_table($form) {
  $header = array(
    array(
      'data' => t('Name'),
      'colspan' => 2,
    ),
    t('Available'),
    t('Weight'),
    t('Operations'),
  );
  $rows = array();
  foreach (element_children($form) as $provider_id) {
    if (isset($form[$provider_id]['icon'])) {
      $row = array(
        drupal_render($form[$provider_id]['hybridauth_provider_' . $provider_id . '_enabled']),
        drupal_render($form[$provider_id]['icon']),
        drupal_render($form[$provider_id]['file']),
        drupal_render($form[$provider_id]['hybridauth_provider_' . $provider_id . '_weight']),
        drupal_render($form[$provider_id]['settings']),
      );
      $rows[] = array(
        'data' => $row,
        'class' => 'draggable',
      );
    }
  }

  //Finally, output the sortable table. Make sure the id is the same as the table id in drupal_add_tabledrag
  $output = theme('table', $header, $rows, array(
    'id' => 'hybridauth-providers',
  ));
  $output .= drupal_render($form);

  //This function is the instantiator of the sorter. Make sure the 0th paramater is the id of your table, and the 3rd paramater is the class of your weight variable
  drupal_add_tabledrag('hybridauth-providers', 'order', 'sibling', 'hybridauth-provider-weight');
  return $output;
}
function hybridauth_admin_provider_settings(&$form_state, $provider_id = NULL) {
  $form = array();
  switch ($provider_id) {
    case 'Facebook':
      $help = t('
          <p>Enter your application ID and private key. You can get these by creating a new application at <a href="!apps_uri">!apps_uri</a>.</p>
          <p>You must set <strong>App Domain</strong> to something like <strong>example.com</strong> to cover <strong>*.example.com</strong>.</p>
          <p>You must set <strong>Site URL</strong> to <strong>%site_uri</strong>.</p>
        ', array(
        '!apps_uri' => 'https://developers.facebook.com/apps',
        '%site_uri' => url('<front>', array(
          'absolute' => TRUE,
        )),
      ));
      break;
    case 'Twitter':
      $help = t('
          <p>Enter your consumer key and private key. You can get these by creating a new application at <a href="!apps_uri">!apps_uri</a>.</p>
        ', array(
        '!apps_uri' => 'https://dev.twitter.com/apps',
      ));
      break;
    case 'Google':
      $origin_uri_parts = parse_url(url('<front>', array(
        'absolute' => TRUE,
      )));
      $help = t('
          <p>Enter your application ID and private key. You can get these by creating a new application at <a href="!apps_uri">!apps_uri</a>.</p>
          <p>You must set <strong>Authorized Redirect URIs</strong> to <strong>%redirect_uri</strong>.</p>
          <p>You must set <strong>Authorized JavaScript Origins</strong> to <strong>%origin_uri</strong>.</p>
        ', array(
        '!apps_uri' => 'https://code.google.com/apis/console#access',
        '%redirect_uri' => url('hybridauth/endpoint', array(
          'absolute' => TRUE,
          'query' => array(
            'hauth.done' => 'Google',
          ),
        )),
        '%origin_uri' => $origin_uri_parts['scheme'] . '://' . $origin_uri_parts['host'],
      ));
      break;
    default:
      $help = t('Enter the application ID, consumer key, and/or secret key as required.');
      break;
  }
  $form['keys'] = array(
    '#type' => 'fieldset',
    '#description' => $help,
  );
  $form['keys']['hybridauth_provider_' . $provider_id . '_keys_id'] = array(
    '#type' => 'textfield',
    '#title' => t('Application ID'),
    '#description' => t('The application ID'),
    '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_keys_id', ''),
  );
  $form['keys']['hybridauth_provider_' . $provider_id . '_keys_key'] = array(
    '#type' => 'textfield',
    '#title' => t('Application consumer key'),
    '#description' => t('The Application consumer key'),
    '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_keys_key', ''),
  );
  $form['keys']['hybridauth_provider_' . $provider_id . '_keys_secret'] = array(
    '#type' => 'textfield',
    '#title' => t('Application consumer secret'),
    '#description' => t('The application consumer secret key'),
    '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_keys_secret', ''),
  );
  if (in_array($provider_id, array(
    'LinkedIn',
    'MySpace',
    'Twitter',
    'Yahoo',
  ))) {
    unset($form['keys']['hybridauth_provider_' . $provider_id . '_keys_id']);
  }
  if (in_array($provider_id, array(
    'Facebook',
    'Google',
    'Live',
    'Vkontakte',
  ))) {
    unset($form['keys']['hybridauth_provider_' . $provider_id . '_keys_key']);
  }
  if ($provider_id == 'Facebook') {
    $form['advanced'] = array(
      '#type' => 'fieldset',
      '#title' => 'Advanced settings',
      '#collapsible' => TRUE,
      '#collapsed' => TRUE,
    );
    $form['advanced']['hybridauth_provider_' . $provider_id . '_scope'] = array(
      '#type' => 'checkboxes',
      '#title' => t('Scope'),
      '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_scope', array(
        'email',
        'user_about_me',
        'user_birthday',
        'user_hometown',
        'user_website',
        'offline_access',
      )),
      '#options' => array(
        // See http://developers.facebook.com/docs/reference/api/permissions/
        // Regular permissions
        'user_about_me' => t('<strong>user_about_me</strong> -- Provides access to the "About Me" section of the profile in the about property'),
        'user_activities' => t('<strong>user_activities</strong> -- Provides access to the user\'s list of activities as the activities connection'),
        'user_birthday' => t('<strong>user_birthday</strong> -- Provides access to the birthday with year as the birthday_date property'),
        'user_checkins' => t('<strong>user_checkins</strong> -- Provides read access to the authorized user\'s check-ins that the user can see.'),
        'user_education_history' => t('<strong>user_education_history</strong> -- Provides access to education history as the education property'),
        'user_events' => t('<strong>user_events</strong> -- Provides access to the list of events the user is attending as the events connection'),
        'user_groups' => t('<strong>user_groups</strong> -- Provides access to the list of groups the user is a member of as the groups connection'),
        'user_hometown' => t('<strong>user_hometown</strong> -- Provides access to the user\'s hometown in the hometown property'),
        'user_interests' => t('<strong>user_interests</strong> -- Provides access to the user\'s list of interests as the interests connection'),
        'user_likes' => t('<strong>user_likes</strong> -- Provides access to the list of all of the pages the user has liked as the likes connection'),
        'user_location' => t('<strong>user_location</strong> -- Provides access to the user\'s current location as the location property'),
        'user_notes' => t('<strong>user_notes</strong> -- Provides access to the user\'s notes as the notes connection'),
        'user_online_presence' => t('<strong>user_online_presence</strong> -- Provides access to the user\'s online/offline presence'),
        'user_photos' => t('<strong>user_photos</strong> -- Provides access to the photos the user has uploaded, and photos the user has been tagged in'),
        'user_questions' => t('<strong>user_questions</strong> -- Provides access to the questions the user or friend has asked'),
        'user_relationships' => t('<strong>user_relationships</strong> -- Provides access to the user\'s family and personal relationships and relationship status'),
        'user_relationship_details' => t('<strong>user_relationship_details</strong> -- Provides access to the user\'s relationship preferences'),
        'user_religion_politics' => t('<strong>user_religion_politics</strong> -- Provides access to the user\'s religious and political affiliations'),
        'user_status' => t('<strong>user_status</strong> -- Provides access to the user\'s most recent status message'),
        'user_videos' => t('<strong>user_videos</strong> -- Provides access to the videos the user has uploaded, and videos the user has been tagged in'),
        'user_website' => t('<strong>user_website</strong> -- Provides access to the user\'s web site URL'),
        'user_work_history' => t('<strong>user_work_history</strong> -- Provides access to work history as the work property'),
        'email' => t('<strong>email</strong> -- Provides access to the user\'s primary email address in the email property. Do not spam users. Your use of email must comply both with Facebook policies and with the CAN-SPAM Act.'),
        // Extended permissions
        'read_friendlists' => t('<strong>read_friendlists</strong> -- Provides access to any friend lists the user created. All user\'s friends are provided as part of basic data, this extended permission grants access to the lists of friends a user has created, and should only be requested if your application utilizes lists of friends.'),
        'read_insights' => t('<strong>read_insights</strong> -- Provides read access to the Insights data for pages, applications, and domains the user owns.'),
        'read_mailbox' => t('<strong>read_mailbox</strong> -- Provides the ability to read from a user\'s Facebook Inbox.'),
        'read_requests' => t('<strong>read_requests</strong> -- Provides read access to the user\'s friend requests'),
        'read_stream' => t('<strong>read_stream</strong> -- Provides access to all the posts in the user\'s News Feed and enables your application to perform searches against the user\'s News Feed'),
        'xmpp_login' => t('<strong>xmpp_login</strong> -- Provides applications that integrate with Facebook Chat the ability to log in users.'),
        'ads_management' => t('<strong>ads_management</strong> -- Provides the ability to manage ads and call the Facebook Ads API on behalf of a user.'),
        'create_event' => t('<strong>create_event</strong> -- Enables your application to create and modify events on the user\'s behalf'),
        'manage_friendlists' => t('<strong>manage_friendlists</strong> -- Enables your app to create and edit the user\'s friend lists.'),
        'manage_notifications' => t('<strong>manage_notifications</strong> -- Enables your app to read notifications and mark them as read. This permission will be required to all access to notifications after October 22, 2011.'),
        'offline_access' => t('<strong>offline_access</strong> -- Enables your app to perform authorized requests on behalf of the user at any time. By default, most access tokens expire after a short time period to ensure applications only make requests on behalf of the user when the are actively using the application. This permission makes the access token returned by our OAuth endpoint long-lived.'),
        'publish_checkins' => t('<strong>publish_checkins</strong> -- Enables your app to perform checkins on behalf of the user.'),
        'publish_stream' => t('<strong>publish_stream</strong> -- Enables your app to post content, comments, and likes to a user\'s stream and to the streams of the user\'s friends. With this permission, you can publish content to a user\'s feed at any time, without requiring offline_access. However, please note that Facebook recommends a user-initiated sharing model.'),
        'rsvp_event' => t('<strong>rsvp_event</strong> -- Enables your application to RSVP to events on the user\'s behalf'),
        'sms' => t('<strong>sms</strong> -- Enables your application to send messages to the user and respond to messages from the user via text message'),
        'publish_actions' => t('<strong>publish_actions</strong> -- Enables your application to publish user scores and achievements.'),
      ),
    );
  }
  if ($provider_id == 'Google') {
    $form['advanced'] = array(
      '#type' => 'fieldset',
      '#title' => 'Advanced settings',
      '#collapsible' => TRUE,
      '#collapsed' => TRUE,
    );
    $form['advanced']['hybridauth_provider_' . $provider_id . '_scope'] = array(
      '#type' => 'textfield',
      '#title' => t('Scope'),
      '#default_value' => variable_get('hybridauth_provider_' . $provider_id . '_scope', 'https://www.googleapis.com/auth/userinfo.profile https://www.googleapis.com/auth/userinfo.email'),
      '#size' => 150,
    );
  }
  return system_settings_form($form);
}
function hybridauth_report() {
  $providers = hybridauth_providers_list();
  $header = array(
    t('Authentication provider'),
    t('Users count'),
  );
  $rows = array();
  $results = db_query('SELECT provider, COUNT(provider_identifier) count FROM {hybridauth_identity} GROUP BY provider');
  while ($result = db_fetch_array($results)) {
    $rows[] = array(
      $providers[$result['provider']],
      $result['count'],
    );
  }
  $form = array();
  $form['report'] = array(
    '#value' => theme('table', $header, $rows),
  );
  return $form;
}

Functions

Namesort descending Description
hybridauth_admin_provider_settings
hybridauth_admin_settings @file Administrative pages forms and functions for the HybridAuth module.
hybridauth_report
theme_hybridauth_admin_settings_providers_table Theme function for hybridauth_admin_settings() to render providers table.