1, ':types' => $node_types)); $operations = array(); foreach ($result as $row) { $operations[] = array('_linkchecker_batch_node_import_op', array($row->nid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_node_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), ); return $batch; } /** * Batch operation: Scan one by one node for links. */ function _linkchecker_batch_node_import_op($nid, &$context) { // Load the node and scan for links. $node = node_load($nid, NULL, TRUE); _linkchecker_add_node_links($node); // Store results for post-processing in the finished callback. $context['results'][] = $node->nid; $context['message'] = t('Content: @title', array('@title' => $node->title)); } /** * Output node batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * Number of nodes scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_node_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'One node has been scanned.', '@count nodes have been scanned.'); } else { $message = t('Scanning for links in content has failed with an error.'); } drupal_set_message($message); } /** * Batch: Scan comments for links. */ function _linkchecker_batch_import_comments($node_types = array()) { // Get all active {comment}.cid's. $result = db_query('SELECT c.cid FROM {comment} c INNER JOIN {node} n ON c.nid = n.nid WHERE c.status = :cstatus AND n.status = :nstatus AND n.type IN (:types) ORDER BY c.cid', array(':cstatus' => COMMENT_PUBLISHED, ':nstatus' => 1, ':types' => $node_types)); $operations = array(); foreach ($result as $row) { $operations[] = array('_linkchecker_batch_comments_import_op', array($row->cid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_comments_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), ); return $batch; } /** * Batch operation: Scan one by one comment for links. */ function _linkchecker_batch_comments_import_op($cid, &$context) { // Load the comment and scan for links. $comment = comment_load($cid); _linkchecker_add_comment_links($comment); // Store results for post-processing in the finished callback. $context['results'][] = $comment->cid; $context['message'] = t('Comment: @title', array('@title' => $comment->subject)); } /** * Output comment batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * Number of comments scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_comments_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'One comment has been scanned.', '@count comments have been scanned.'); } else { $message = t('Scanning for links in comments have failed with an error.'); } drupal_set_message($message); } /** * Batch: Scan blocks for links. */ function _linkchecker_batch_import_block_custom() { // Get all {block_custom}.bid's as block module suxxx and has no usable hooks. $result = db_query('SELECT bid FROM {block_custom} ORDER BY bid'); $operations = array(); foreach ($result as $row) { $operations[] = array('_linkchecker_batch_import_block_custom_op', array($row->bid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_block_custom_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), ); return $batch; } /** * Batch operation: Scan one by one block for links. */ function _linkchecker_batch_import_block_custom_op($bid, &$context) { // Load the custom block and scan for links. $block_custom = linkchecker_block_custom_block_get($bid); _linkchecker_add_block_custom_links($block_custom, $block_custom->delta); // Store some result for post-processing in the finished callback. $context['results'][] = $block_custom->delta; $context['message'] = t('Block: @title', array('@title' => $block_custom->info)); } /** * Output block batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * Number of blocks scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_block_custom_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'One block has been scanned.', '@count blocks have been scanned.'); } else { $message = t('Scanning for links in blocks have failed with an error.'); } drupal_set_message($message); } /** * Recurring scans of a single node via batch API. * * @param int $nid * The unique node id to scan for links. * @param int $missing_links_count * The number of links not yet added to linkchecker_links table. By this * number the re-scan rounds are calulated. * * @return array * The batch task definition. */ function _linkchecker_batch_import_single_node($nid, $missing_links_count) { $operations = array(); for ($i = 0; $i <= $missing_links_count; $i = $i + LINKCHECKER_SCAN_MAX_LINKS_PER_RUN) { $operations[] = array('_linkchecker_batch_single_node_import_op', array($nid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_single_node_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), 'progress_message' => t('Remaining @remaining of @total scans.'), ); return $batch; } /** * Run single node link extraction. * * @param int $nid * Node ID. * @param array $context * Batch context array. */ function _linkchecker_batch_single_node_import_op($nid, &$context) { // Load the node and scan for links. $node = node_load($nid, NULL, TRUE); _linkchecker_add_node_links($node, TRUE); // Store results for post-processing in the finished callback. $context['results'][] = $node->nid; $context['message'] = t('Content: @title', array('@title' => $node->title)); } /** * Output single node batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * How often the node has been scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_single_node_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'Node @nid has been re-scanned once to collect all links.', 'Node @nid has been re-scanned @count times to collect all links.', array('@nid' => $results[0])); } else { $message = t('Recurring scanning for links in node @nid has failed with an error.', array('@nid' => $results[0])); } drupal_set_message($message); } /** * Recurring scans of a single comment via batch API. * * @param int $cid * The unique comment id to scan for links. * @param int $missing_links_count * The number of links not yet added to linkchecker_links table. By this * number the re-scan rounds are calulated. * * @return array * The batch task definition. */ function _linkchecker_batch_import_single_comment($cid, $missing_links_count) { $operations = array(); for ($i = 0; $i <= $missing_links_count; $i = $i + LINKCHECKER_SCAN_MAX_LINKS_PER_RUN) { $operations[] = array('_linkchecker_batch_single_comment_import_op', array($cid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_single_comment_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), 'progress_message' => t('Remaining @remaining of @total scans.'), ); return $batch; } /** * Run single comment link extraction. * * @param int $cid * Comment ID. * @param array $context * Batch context array. */ function _linkchecker_batch_single_comment_import_op($cid, &$context) { $comment = comment_load($cid); _linkchecker_add_comment_links($comment, TRUE); // Store results for post-processing in the finished callback. $context['results'][] = $comment->cid; $context['message'] = t('Comment: @title', array('@title' => $comment->subject)); } /** * Output single comment batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * How often the comment has been scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_single_comment_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'Comment @cid has been re-scanned once to collect all links.', 'Comment @cid has been re-scanned @count times to collect all links.', array('@cid' => $results[0])); } else { $message = t('Recurring scanning for links in comment @cid has failed with an error.', array('@cid' => $results[0])); } drupal_set_message($message); } /** * Recurring scans of a single block via batch API. * * @param int $bid * The unique block id to scan for links. * @param int $missing_links_count * The number of links not yet added to linkchecker_links table. By this * number the re-scan rounds are calulated. * * @return array * The batch task definition. */ function _linkchecker_batch_import_single_block_custom($bid, $missing_links_count) { $operations = array(); for ($i = 0; $i <= $missing_links_count; $i = $i + LINKCHECKER_SCAN_MAX_LINKS_PER_RUN) { $operations[] = array('_linkchecker_batch_single_block_custom_import_op', array($bid)); } $batch = array( 'file' => drupal_get_path('module', 'linkchecker') . '/linkchecker.batch.inc', 'finished' => '_linkchecker_batch_single_block_custom_import_finished', 'operations' => $operations, 'title' => t('Scanning for links'), 'progress_message' => t('Remaining @remaining of @total scans.'), ); return $batch; } /** * Run single block link extraction. * * @param int $bid * Node ID. * @param array $context * Batch context array. */ function _linkchecker_batch_single_block_custom_import_op($bid, &$context) { // Load the custom block and scan for links. $block_custom = linkchecker_block_custom_block_get($bid); _linkchecker_add_block_custom_links($block_custom, $block_custom->delta, TRUE); // Store some result for post-processing in the finished callback. $context['results'][] = $block_custom->delta; $context['message'] = t('Block: @title', array('@title' => $block_custom->info)); } /** * Output single block batch result messages. * * @param bool $success * If scan completed successfully or not. * @param int $results * How often the block has been scanned. * @param array $operations * Array of functions called. */ function _linkchecker_batch_single_block_custom_import_finished($success, $results, $operations) { if ($success) { $message = format_plural(count($results), 'Block @bid has been re-scanned once to collect all links.', 'Block @bid has been re-scanned @count times to collect all links.', array('@bid' => $results[0])); } else { $message = t('Recurring scanning for links in block @bid has failed with an error.', array('@bid' => $results[0])); } drupal_set_message($message); }