webmaster@1: name)); webmaster@1: drupal_add_css(drupal_get_path('module', 'openid') .'/openid.css', 'module'); webmaster@1: webmaster@1: // Check to see if we got a response webmaster@1: $result = openid_complete(); webmaster@1: if ($result['status'] == 'success') { webmaster@1: $identity = $result['openid.claimed_id']; webmaster@1: db_query("INSERT INTO {authmap} (uid, authname, module) VALUES (%d, '%s','openid')", $account->uid, $identity); webmaster@1: drupal_set_message(t('Successfully added %identity', array('%identity' => $identity))); webmaster@1: } webmaster@1: webmaster@1: $header = array(t('OpenID'), t('Operations')); webmaster@1: $rows = array(); webmaster@1: webmaster@1: $result = db_query("SELECT * FROM {authmap} WHERE module='openid' AND uid=%d", $account->uid); webmaster@1: while ($identity = db_fetch_object($result)) { webmaster@7: $rows[] = array(check_plain($identity->authname), l(t('Delete'), 'user/'. $account->uid .'/openid/delete/'. $identity->aid)); webmaster@1: } webmaster@1: webmaster@1: $output = theme('table', $header, $rows); webmaster@1: $output .= drupal_get_form('openid_user_add'); webmaster@1: return $output; webmaster@1: } webmaster@1: webmaster@1: /** webmaster@1: * Form builder; Add an OpenID identity. webmaster@1: * webmaster@1: * @ingroup forms webmaster@1: * @see openid_user_add_validate() webmaster@1: */ webmaster@1: function openid_user_add() { webmaster@1: $form['openid_identifier'] = array( webmaster@1: '#type' => 'textfield', webmaster@1: '#title' => t('OpenID'), webmaster@1: ); webmaster@1: $form['submit'] = array('#type' => 'submit', '#value' => t('Add an OpenID')); webmaster@1: return $form; webmaster@1: } webmaster@1: webmaster@1: function openid_user_add_validate($form, &$form_state) { webmaster@1: // Check for existing entries. webmaster@1: $claimed_id = _openid_normalize($form_state['values']['openid_identifier']); webmaster@1: if (db_result(db_query("SELECT authname FROM {authmap} WHERE authname='%s'", $claimed_id))) { webmaster@1: form_set_error('openid_identifier', t('That OpenID is already in use on this site.')); webmaster@1: } webmaster@1: else { webmaster@1: $return_to = url('user/'. arg(1) .'/openid', array('absolute' => TRUE)); webmaster@1: openid_begin($form_state['values']['openid_identifier'], $return_to); webmaster@1: } webmaster@1: } webmaster@1: webmaster@1: /** webmaster@7: * Present a confirmation form to delete the specified OpenID identity from the system. webmaster@7: * webmaster@7: * @ingroup forms webmaster@7: * @see openid_user_delete_form_submit() webmaster@1: */ webmaster@7: function openid_user_delete_form($form_state, $account, $aid = 0) { webmaster@7: $authname = db_result(db_query('SELECT authname FROM {authmap} WHERE uid = %d AND aid = %d', $account->uid, $aid)); webmaster@7: webmaster@7: $form = array(); webmaster@7: webmaster@7: $form['uid'] = array( webmaster@7: '#type' => 'value', webmaster@7: '#value' => $account->uid, webmaster@7: ); webmaster@7: webmaster@7: $form['aid'] = array( webmaster@7: '#type' => 'value', webmaster@7: '#value' => $aid, webmaster@7: ); webmaster@7: webmaster@7: return confirm_form($form, t('Are you sure you want to delete the OpenID %authname for %user?', array('%authname' => $authname, '%user' => $account->name)), 'user/'. $account->uid .'/openid'); webmaster@7: } webmaster@7: webmaster@7: function openid_user_delete_form_submit($form, &$form_state) { webmaster@7: db_query("DELETE FROM {authmap} WHERE uid = %d AND aid = %d AND module = 'openid'", $form_state['values']['uid'], $form_state['values']['aid']); webmaster@1: if (db_affected_rows()) { webmaster@1: drupal_set_message(t('OpenID deleted.')); webmaster@1: } webmaster@7: $form_state['redirect'] = 'user/'. $form_state['values']['uid'] .'/openid'; webmaster@1: }