/** * Returns all available updates for a given version * * @param type $version */ public static function getAvailableUpdate() { $info = []; if (class_exists('\\humhub\\modules\\admin\\libs\\HumHubAPI')) { $info = \humhub\modules\admin\libs\HumHubAPI::request('v1/modules/getHumHubUpdates', ['updaterVersion' => Yii::$app->getModule('updater')->version]); } else { // older Versions try { $url = Yii::$app->getModule('admin')->marketplaceApiUrl . "getHumHubUpdates?version=" . Yii::$app->version . "&updaterVersion=" . Yii::$app->getModule('updater')->version . "&installId=" . Setting::Get('installationId', 'admin'); $http = new \Zend\Http\Client($url, array('adapter' => '\\Zend\\Http\\Client\\Adapter\\Curl', 'curloptions' => Yii::$app->getModule('updater')->getCurlOptions(), 'timeout' => 30)); $response = $http->send(); $info = Json::decode($response->getBody()); } catch (Exception $ex) { throw new Exception(Yii::t('UpdaterModule.base', 'Could not get update info online! (%error%)', array('%error%' => $ex->getMessage()))); } } if (!isset($info['fromVersion'])) { return null; } $package = new UpdatePackage($info['fileName'], $info['fromVersion'], $info['toVersion']); $package->md5 = $info['md5']; $package->downloadUrl = $info['downloadUrl']; return $package; }
/** * Get an UserSetting Value * * @param String $name of setting * @param String $moduleId of setting * @param String $default value when no setting exists * @return String */ public function getSetting($name, $moduleId = "core", $default = "") { return Setting::Get($this->owner->id, $name, $moduleId, $default); }
/** * Reads out all users from configured ldap backend and creates or update * existing users. * * Also disabling deleted ldap users in humhub */ public function refreshUsers() { $ldapUserIds = array(); try { $items = $this->ldap->search(Setting::Get('userFilter', 'authentication_ldap'), Setting::Get('baseDn', 'authentication_ldap'), \Zend\Ldap\Ldap::SEARCH_SCOPE_SUB); foreach ($items as $item) { $node = \Zend\Ldap\Node::fromArray($item); $user = $this->handleLdapUser($node); if ($user != null) { $ldapUserIds[] = $user->id; } } foreach (User::find()->where(['auth_mode' => User::AUTH_MODE_LDAP])->each() as $user) { if (!in_array($user->id, $ldapUserIds)) { if ($user->status != User::STATUS_DISABLED) { // User no longer available in ldap $user->status = User::STATUS_DISABLED; \humhub\modules\user\models\Setting::Set($user->id, 'disabled_by_ldap', true, 'user'); $user->save(); Yii::warning('Disabled user ' . $user->username . ' (' . $user->id . ') - Not found in LDAP!'); } } else { if ($user->status == User::STATUS_DISABLED && \humhub\modules\user\models\Setting::Get($user->id, 'disabled_by_ldap', 'user', false)) { // User no longer available in ldap $user->status = User::STATUS_ENABLED; \humhub\modules\user\models\Setting::Set($user->id, 'disabled_by_ldap', '', 'user'); $user->save(); Yii::info('Reenabled disabled user ' . $user->username . ' (' . $user->id . ') - Found again in LDAP!'); } } } } catch (Exception $ex) { Yii::error($ex->getMessage()); } }