2012-01-20 18:10:48 +01:00
< ? php
2015-09-11 09:13:48 +12:00
2012-01-20 18:10:48 +01:00
/**
2015-09-11 09:13:48 +12:00
* Check that the given file is writable .
2012-01-20 18:10:48 +01:00
*/
class FileWriteableCheck implements EnvironmentCheck {
2015-09-11 09:13:48 +12:00
/**
* @ var string
*/
2012-01-20 18:10:48 +01:00
protected $path ;
2015-09-11 09:13:48 +12:00
/**
* @ param string $path The full path . If a relative path , it will relative to the BASE_PATH .
*/
2012-01-20 18:10:48 +01:00
function __construct ( $path ) {
$this -> path = $path ;
}
2015-09-11 09:13:48 +12:00
/**
* @ inheritdoc
*
* @ return array
*/
2012-01-20 18:10:48 +01:00
function check () {
if ( $this -> path [ 0 ] == '/' ) $filename = $this -> path ;
else $filename = BASE_PATH . DIRECTORY_SEPARATOR . str_replace ( '/' , DIRECTORY_SEPARATOR , $this -> path );
if ( file_exists ( $filename )) $isWriteable = is_writeable ( $filename );
else $isWriteable = is_writeable ( dirname ( $filename ));
if ( ! $isWriteable ) {
if ( function_exists ( 'posix_getgroups' )) {
$userID = posix_geteuid ();
$user = posix_getpwuid ( $userID );
$currentOwnerID = fileowner ( file_exists ( $filename ) ? $filename : dirname ( $filename ) );
$currentOwner = posix_getpwuid ( $currentOwnerID );
$message = " User ' $user[name] ' needs to be able to write to this file: \n $filename\n\nThe file is currently owned by ' $currentOwner[name] '. " ;
if ( $user [ 'name' ] == $currentOwner [ 'name' ]) {
$message .= " We recommend that you make the file writeable. " ;
} else {
$groups = posix_getgroups ();
$groupList = array ();
foreach ( $groups as $group ) {
$groupInfo = posix_getgrgid ( $group );
if ( in_array ( $currentOwner [ 'name' ], $groupInfo [ 'members' ])) $groupList [] = $groupInfo [ 'name' ];
}
if ( $groupList ) {
$message .= " We recommend that you make the file group-writeable and change the group to one of these groups: \n - " . implode ( " \n - " , $groupList )
. " \n \n For example: \n chmod g+w $filename\nchgrp " . $groupList [ 0 ] . " $filename " ;
} else {
$message .= " There is no user-group that contains both the web-server user and the owner of this file. Change the ownership of the file, create a new group, or temporarily make the file writeable by everyone during the install process. " ;
}
}
} else {
2012-12-17 17:16:10 +13:00
$message = " The webserver user needs to be able to write to this file: \n $filename " ;
2012-01-20 18:10:48 +01:00
}
return array ( EnvironmentCheck :: ERROR , $message );
}
return array ( EnvironmentCheck :: OK , '' );
}
2015-09-11 09:13:48 +12:00
}