source: extensions/oAuth/admin/providers.php @ 20323

Last change on this file since 20323 was 20323, checked in by mistic100, 12 years ago

fix redirect error, provide 3 sizes of icons, display login info on register page

File size: 2.0 KB
Line 
1<?php
2defined('OAUTH_PATH') or die('Hacking attempt!');
3
4$PROVIDERS_CONFIG = include(OAUTH_PATH . 'include/providers_stats.inc.php');
5
6if (isset($_POST['save_config']))
7{
8  array_walk_recursive($_POST, 'trim');
9 
10  $providers = array();
11  foreach ($_POST['providers'] as $id => $data)
12  {
13    $error = false;
14    $data['enabled'] = $data['enabled']=='true';
15   
16    if ($PROVIDERS_CONFIG[$id]['new_app_link'] and $data['enabled'])
17    {
18      if (empty($data['keys']['secret']) or
19        (@$PROVIDERS_CONFIG[$id]['require_client_id'] and empty($data['keys']['id'])) or
20        (!@$PROVIDERS_CONFIG[$id]['require_client_id'] and empty($data['keys']['key']))
21      ) {
22        array_push($page['errors'], sprintf(l10n('%s: invalid keys'), $PROVIDERS_CONFIG[$id]['provider_name']));
23        $error = true;
24      }
25    }
26    else
27    {
28      unset($data['keys']);
29    }
30   
31    if ( ($id=='Wordpress' or $id=='Flickr') and $data['enabled'] and !@$providers['OpenID']['enabled'] )
32    {
33      array_push($page['errors'], sprintf(l10n('OpenID must be enabled in order to use %s authentication'), $id));
34      $error = true;
35    }
36   
37    if (isset($PROVIDERS_CONFIG[$id]['scope']))
38    {
39      $data['scope'] = $PROVIDERS_CONFIG[$id]['scope'];
40    }
41   
42    if (!$error)
43    {
44      $providers[$id] = $data;
45    }
46  }
47 
48  if (!count($page['errors']))
49  {
50    // generate config file
51    $hybridauth_conf['providers'] = $providers;
52    $content = "<?php\ndefined('PHPWG_ROOT_PATH') or die('Hacking attempt!');\n\nreturn ";
53    $content.= var_export(array('providers'=>$providers), true);
54    $content.= ";\n?>";
55    file_put_contents(OAUTH_CONFIG, $content);
56  }
57}
58
59
60$template->assign(array(
61  'PROVIDERS' => $PROVIDERS_CONFIG,
62  'CONFIG' => $hybridauth_conf['providers'],
63  'SERVERNAME' => get_absolute_root_url(),
64  'OAUTH_CALLBACK' => OAUTH_PUBLIC . '?hauth.done=',
65  ));
66
67// define template file
68$template->set_filename('oauth_content', realpath(OAUTH_PATH . 'admin/template/providers.tpl'));
69
70?>
Note: See TracBrowser for help on using the repository browser.