You are here

function hook_file_move in Drupal 7

Same name and namespace in other branches
  1. 8 core/modules/file/file.api.php \hook_file_move()
  2. 9 core/modules/file/file.api.php \hook_file_move()
  3. 10 core/modules/file/file.api.php \hook_file_move()

Respond to a file that has been moved.

Parameters

$file: The updated file object after the move.

$source: The original file object before the move.

See also

file_move()

Related topics

3 functions implement hook_file_move()

Note: this list is generated by pattern matching, so it may include some functions that are not actually implementations of this hook.

file_test_file_move in modules/simpletest/tests/file_test.module
Implements hook_file_move().
image_file_move in modules/image/image.module
Implements hook_file_move().
user_file_move in modules/user/user.module
Implements hook_file_move().
1 invocation of hook_file_move()
file_move in includes/file.inc
Moves a file to a new location and update the file's database entry.

File

modules/system/system.api.php, line 2965
Hooks provided by Drupal core and the System module.

Code

function hook_file_move($file, $source) {
  $file_user = user_load($file->uid);

  // Make sure that the file name starts with the owner's user name.
  if (strpos($file->filename, $file_user->name) !== 0) {
    $file->filename = $file_user->name . '_' . $file->filename;
    $file
      ->save();
    watchdog('file', t('Moved file %source has been renamed to %destination', array(
      '%source' => $source->filename,
      '%destination' => $file->filename,
    )));
  }
}