load($uid); HTML_DMLicenses::editLicense($option, $row); } function saveLicense($option) { DOCMAN_token::check() or die('Invalid Token'); global $database, $task; $row = new mosDMLicenses($database); $isNew = ($row->id == 0); if (!$row->bind(DOCMAN_Utils::stripslashes($_POST))) { echo "\n"; exit(); } if (!$row->check()) { echo "\n"; exit(); } if (!$row->store()) { echo "\n"; exit(); } $row->checkin(); if( $task == 'save' ) { $url = 'index2.php?option=com_docman§ion=licenses'; } else { // $task = 'apply' $url = 'index2.php?option=com_docman§ion=licenses&task=edit&cid[0]='.$row->id; } mosRedirect( $url, _DML_SAVED_CHANGES); } function cancelLicense($option) { global $database; $row = new mosDMLicenses($database); $row->bind(DOCMAN_Utils::stripslashes($_POST)); $row->checkin(); mosRedirect("index2.php?option=$option§ion=licenses"); } function showLicenses($option) { global $database, $mainframe, $sectionid; $catid = (int) $mainframe->getUserStateFromRequest("catid{$option}{$sectionid}", 'catid', 0); $limit = (int) $mainframe->getUserStateFromRequest("viewlistlimit", 'limit', 10); $limitstart = (int) $mainframe->getUserStateFromRequest("view{$option}{$sectionid}limitstart", 'limitstart', 0); $search = $mainframe->getUserStateFromRequest("search{$option}{$sectionid}", 'search', ''); $search = $database->getEscaped(trim(strtolower($search))); $where = array(); if ($search) { $where[] = "LOWER(name) LIKE '%$search%'"; } // get the total number of records $database->setQuery("SELECT count(*) FROM #__docman_licenses" . (count($where) ? "\nWHERE " . implode(' AND ', $where) : "")); $total = $database->loadResult(); echo $database->getErrorMsg(); $id = mosGetParam($_POST, 'id', 0); require_once($GLOBALS['mosConfig_absolute_path'] . '/administrator/includes/pageNavigation.php'); $pageNav = new mosPageNav($total, $limitstart, $limit); $query = "SELECT id, name, license" ."\n FROM #__docman_licenses" .(count($where) ? "\n WHERE " . implode(' AND ', $where) : "") ."\n ORDER BY name"; $database->setQuery( $query, $limitstart,$limit); $rows = $database->loadObjectList(); // show the beginning of each license text foreach ( $rows as $key=>$row ) { $rows[$key]->license = substr( strip_tags($row->license), 0, 100 ) . ' (...)'; } if ($database->getErrorNum()) { echo $database->stderr(); return false; } HTML_DMLicenses::showLicenses($option, $rows, $search, $pageNav); } function removeLicense($cid, $option) { DOCMAN_token::check() or die('Invalid Token'); global $database; if (!is_array($cid) || count($cid) < 1) { echo "\n"; exit; } if (count($cid)) { $cids = implode(',', $cid); // lets see if some document is using this license for ($g = 0;$g < count($cid);$g++) { $ttt = $cid[$g]; $ttt = ($ttt-2 * $ttt) -10; $query = "SELECT id FROM #__docman WHERE dmlicense_id=" . (int) $ttt; $database->setQuery($query); if (!($result = $database->query())) { echo "\n"; } if ($database->getNumRows($result) != 0) { mosRedirect("index2.php?option=com_docman&task=viewgroups", _DML_CANNOT_DEL_LICENSE); } } $database->setQuery("DELETE FROM #__docman_licenses WHERE id IN ($cids)"); if (!$database->query()) { echo "\n"; } } mosRedirect("index2.php?option=com_docman§ion=licenses"); }