domain_content.admin.inc
<?php
function domain_content_page() {
$content = array();
$content = system_admin_menu_block(menu_get_item('admin/domain/content'));
if (!empty($content)) {
$output = theme('admin_block_content', $content);
}
else {
$output = t('There are no valid domains configured.');
}
return $output;
}
function domain_content_list() {
global $user;
if (user_access('administer nodes') || user_access('review content for all domains')) {
$query = "SELECT domain_id, subdomain, sitename, scheme FROM {domain} d";
}
else {
if (empty($user->domain_user)) {
return drupal_access_denied();
}
if (isset($user->domain_user[-1])) {
unset($user->domain_user[-1]);
$user->domain_user[0] = 0;
}
$query = "SELECT domain_id, subdomain, sitename, scheme FROM {domain} WHERE domain_id IN (". db_placeholders($user->domain_user, 'int') .")";
}
$header = array(
array('data' => t('Id'), 'field' => 'domain_id'),
array('data' => t('Site content'), 'field' => 'sitename'),
array('data' => t('Content count')),
array('data' => t('Site'), 'field' => 'subdomain'),
);
$query .= tablesort_sql($header);
$result = pager_query($query, variable_get('domain_list_size', DOMAIN_LIST_SIZE), 0, NULL, $user->domain_user);
$rows = array();
while ($domain = db_fetch_array($result)) {
$path = trim(domain_get_path($domain), '/');
$rows[] = array(
$domain['domain_id'],
l(t('!sitename content', array('!sitename' => $domain['sitename'])), 'admin/domain/content/'. $domain['domain_id']),
(int) db_result(db_query("SELECT COUNT(*) FROM {domain_access} WHERE gid = %d AND realm = 'domain_id'", $domain['domain_id'])),
l(t('view site'), $path),
);
}
$all = array(
'-',
l(t('Content assigned to all affiliates'), 'admin/domain/content/all'),
(int) db_result(db_query("SELECT COUNT(*) FROM {domain_access} WHERE gid = 0 AND realm = 'domain_site'")),
'',
);
array_unshift($rows, $all);
if (!empty($rows)) {
$output = '<p>'. t('The table below shows all the affiliates sites whose content you may edit. Click on the site name link to see all content assigned to that affiliate.') .'</p>';
$output .= theme_table($header, $rows);
$output .= theme('pager', NULL, variable_get('domain_list_size', DOMAIN_LIST_SIZE), 0);
return $output;
}
else {
return t('You do not have editing access to any domains. Please contact your site administrator.');
}
}
function domain_content_view($domain_id = NULL, $all_affiliates = FALSE) {
global $_domain;
if (!is_null($domain_id) && $domain_id != $_domain['domain_id']) {
domain_set_domain($domain_id);
}
$output = '';
if (!is_null($domain_id)) {
$_domain['site_grant'] = FALSE;
drupal_set_title(t('Content for !domain', array('!domain' => $_domain['sitename'])));
}
else if ($all_affiliates) {
$_domain['site_grant'] = TRUE;
drupal_set_title(t('Content for all affiliate sites'));
}
else {
drupal_set_message(t('Invalid request'), 'error');
$output .= t('<p>The specified domain does not exist.</p>');
return $output;
}
$output .= domain_content_admin();
return $output;
}
function domain_content_admin() {
include_once drupal_get_path('module', 'node') .'/node.admin.inc';
$output = drupal_get_form('node_filter_form');
if (isset($_POST['nodes']) && $_POST['operation'] == 'delete') {
return drupal_get_form('node_multiple_delete_confirm', $_POST['nodes']);
}
$output .= drupal_get_form('domain_content_form');
return $output;
}
function domain_content_form($form_state) {
global $_domain;
$filter = node_build_filter_query();
$filter['join'] .= " INNER JOIN {domain_access} dac ON dac.nid = n.nid ";
$arg = arg(3);
if ($arg != 'all') {
if (empty($filter['where'])) {
$filter['where'] = " WHERE dac.realm = 'domain_id' AND dac.gid = ". intval($_domain['domain_id']) ." ";
}
else {
$filter['where'] .= " AND dac.realm = 'domain_id' AND dac.gid = ". intval($_domain['domain_id']) ." ";
}
}
else {
if (empty($filter['where'])) {
$filter['where'] = " WHERE dac.realm = 'domain_site' AND dac.gid = 0 ";
}
else {
$filter['where'] .= " AND dac.realm = 'domain_site' AND dac.gid = 0 ";
}
}
$result = pager_query(db_rewrite_sql('SELECT nid FROM {node} n '. $filter['join'] . $filter['where'] .' ORDER BY n.changed DESC'), 50, 0, NULL, $filter['args']);
$nodes = array();
while ($nid = db_fetch_object($result)) {
$node = node_load($nid->nid);
$form['title'][$node->nid] = array('#value' => l($node->title, 'node/'. $node->nid) .' '. theme('mark', node_mark($node->nid, $node->changed)));
$form['name'][$node->nid] = array('#value' => check_plain(node_get_types('name', $node)));
$form['username'][$node->nid] = array('#value' => theme('username', $node));
$form['status'][$node->nid] = array('#value' => ($node->status ? t('published') : t('not published')));
$node_domains = array();
if (!empty($node->domains)) {
foreach ($node->domains as $domain) {
$key = ($domain == -1) ? 0 : $domain;
$node_domains[] = domain_lookup($key);
}
}
$items = array();
if ($node->domain_site) {
$items[-1] = t('All affiliates');
}
if (!empty($node_domains)) {
foreach ($node_domains as $item) {
$items[$item['domain_id']] = $item['sitename'];
}
}
if (module_exists('domain_source')) {
$source = NULL;
$source = db_fetch_object(db_query("SELECT domain_id FROM {domain_source} WHERE nid = %d", $node->nid));
if (!empty($source) && isset($items[$source->domain_id])) {
$items[$source->domain_id] .= '*';
}
}
$form['domains'][$node->nid] = array('#value' => theme('item_list', $items));
if (node_access('update', $node)) {
$form['operations'][$node->nid] = array('#value' => l(t('edit'), 'node/'. $node->nid .'/edit', array('query' => drupal_get_destination())));
$nodes[$node->nid] = '';
}
}
if (user_access('set domain access')) {
$options = array();
$format = domain_select_format();
foreach (domain_domains() as $data) {
($data['domain_id'] == 0) ? $key = -1 : $key = $data['domain_id'];
if ($data['valid'] || user_access('access inactive domains')) {
$options[$key] = empty($format) ? check_plain($data['sitename']) : $data['sitename'];
}
}
$form['domain'] = array(
'#type' => 'fieldset',
'#title' => t('Affiliate publishing options'),
'#collapsible' => TRUE,
'#collapsed' => TRUE,
'#prefix' => '<div class="description">'. t('If you select <em>Change affiliate publishing options</em> above, you should confirm the <em>Affiliate publishing options</em> settings below.') .'</div>'
);
$form['domain']['domain_site'] = array(
'#type' => 'checkbox',
'#prefix' => t('<p><b>Publishing options:</b>'),
'#suffix' => '</p>',
'#title' => t('Send to all affiliates'),
'#required' => FALSE,
'#description' => t('Select if this content can be shown to all affiliates. This setting will override the options below.'),
'#default_value' => variable_get('domain_behavior', DOMAIN_INSTALL_RULE),
);
$form['domain']['domains'] = array(
'#type' => empty($format) ? 'checkboxes' : 'select',
'#title' => t('Publish to'),
'#options' => $options,
'#required' => FALSE,
'#description' => t('Select which affiliates can access this content.'),
'#default_value' => array(($_domain['domain_id'] == 0) ? -1 : $_domain['domain_id']), );
if ($format) {
$form['domain']['domains']['#multiple'] = TRUE;
$form['domain']['domains']['#size'] = count($options) > 10 ? 10 : count($options);
}
}
if ((user_access('administer nodes') || user_access('set domain access')) && !empty($nodes)) {
$form['options'] = array('#type' => 'fieldset',
'#title' => t('Update options'),
'#prefix' => '<div class="container-inline">',
'#suffix' => '</div>',
'#weight' => -1
);
$options = array();
foreach (module_invoke_all('node_operations') as $operation => $array) {
$options[$operation] = $array['label'];
}
$form['options']['operation'] = array('#type' => 'select', '#options' => $options, '#default_value' => 'approve');
$form['options']['submit'] = array('#type' => 'submit', '#value' => t('Update'));
$form['nodes'] = array('#type' => 'checkboxes', '#options' => $nodes);
domain_content_filter_operations($form['options']['operation']['#options']);
}
$form['pager'] = array('#value' => theme('pager', NULL, 50, 0));
$form['#theme'] = 'domain_content_admin_nodes';
$form['#validate'][] = 'node_admin_nodes_validate';
$form['#submit'][] = 'node_admin_nodes_submit';
$form['#submit'][] = 'domain_content_update_nodes';
return $form;
}
function domain_content_filter_operations(&$operations) {
$settings = variable_get('domain_form_elements', array('options', 'delete', 'comment_settings', 'path'));
if (user_access('administer nodes')) {
return;
}
if (!user_access('delete domain nodes')) {
unset($operations['delete']);
}
if (!in_array('options', array_filter($settings))) {
unset($operations['publish']);
unset($operations['unpublish']);
unset($operations['promote']);
unset($operations['demote']);
unset($operations['sticky']);
unset($operations['unsticky']);
}
}
function domain_content_update_nodes($form, &$form_state) {
if ($form_state['values']['operation'] == 'domain') {
if ($form_state['values']['domain_site']) {
$domain_site = TRUE;
}
$domains = array();
foreach ($form_state['values']['domains'] as $key => $value) {
if (abs($key) > 0 && $key == $value) {
($key == -1) ? $id = 0 : $id = $value;
$domains[] = $id;
}
}
foreach ($form_state['values']['nodes'] as $nid) {
if ($nid > 0) {
db_query("DELETE FROM {node_access} WHERE nid = %d AND realm IN ('domain_id', 'domain_site')", $nid);
db_query("DELETE FROM {domain_access} WHERE nid = %d", $nid);
if (isset($domain_site)) {
db_query("INSERT INTO {node_access} (nid, gid, realm, grant_view, grant_update, grant_delete) VALUES (%d, %d, '%s', %d, %d, %d)", $nid, 0, 'domain_site', 1, 0, 0);
db_query("INSERT INTO {domain_access} (nid, gid, realm) VALUES (%d, %d, '%s')", $nid, 0, 'domain_site');
}
if (!empty($domains)) {
foreach ($domains as $id) {
db_query("INSERT INTO {node_access} (nid, gid, realm, grant_view, grant_update, grant_delete) VALUES (%d, %d, '%s', %d, %d, %d)", $nid, $id, 'domain_id', 1, 1, 1);
db_query("INSERT INTO {domain_access} (nid, gid, realm) VALUES (%d, %d, '%s')", $nid, $id, 'domain_id');
}
}
}
}
}
cache_clear_all();
}
function theme_domain_content_admin_nodes($form) {
$header = array(theme('table_select_header_cell'), t('Title'), t('Affiliates'), t('Type'), t('Author'), t('Status'), t('Operations'));
$output = '';
$output .= drupal_render($form['options']);
$output .= drupal_render($form['domain']);
if (isset($form['title']) && is_array($form['title'])) {
foreach (element_children($form['title']) as $key) {
$row = array();
$row[] = drupal_render($form['nodes'][$key]);
$row[] = drupal_render($form['title'][$key]);
$row[] = drupal_render($form['domains'][$key]);
$row[] = drupal_render($form['name'][$key]);
$row[] = drupal_render($form['username'][$key]);
$row[] = drupal_render($form['status'][$key]);
$row[] = drupal_render($form['operations'][$key]);
$rows[] = $row;
}
}
else {
$rows[] = array(array('data' => t('No posts available.'), 'colspan' => '6'));
}
$output .= theme('table', $header, $rows);
if ($form['pager']['#value']) {
$output .= drupal_render($form['pager']);
}
$output .= drupal_render($form);
return $output;
}