XylotrechusZ
<?php
if ( ! defined( 'ABSPATH' ) ) {
die( 'You are not allowed to call this page directly.' );
}
class FrmCreateFile {
public $folder_name;
public $file_name;
public $error_message;
public $uploads;
private $new_file_path;
public $chmod_dir = 0755;
public $chmod_file = 0644;
private $has_permission = false;
public function __construct( $atts ) {
$this->folder_name = isset( $atts['folder_name'] ) ? $atts['folder_name'] : '';
$this->file_name = $atts['file_name'];
$this->error_message = isset( $atts['error_message'] ) ? $atts['error_message'] : '';
$this->uploads = wp_upload_dir();
$this->set_new_file_path( $atts );
$this->chmod_dir = defined( 'FS_CHMOD_DIR' ) ? FS_CHMOD_DIR : ( fileperms( ABSPATH ) & 0777 | 0755 );
$this->chmod_file = defined( 'FS_CHMOD_FILE' ) ? FS_CHMOD_FILE : ( fileperms( ABSPATH . 'index.php' ) & 0777 | 0644 );
$this->check_permission();
}
/**
* @since 3.0
*
* @return void
*/
private function set_new_file_path( $atts ) {
if ( isset( $atts['new_file_path'] ) ) {
$this->new_file_path = $atts['new_file_path'] . '/' . $this->file_name;
} else {
$this->new_file_path = $this->uploads['basedir'] . '/' . $this->folder_name . '/' . $this->file_name;
}
}
/**
* @param string $file_content
*
* @return void
*/
public function create_file( $file_content ) {
if ( $this->has_permission ) {
$dirs_exist = true;
// Create the directories if need be.
$this->create_directories( $dirs_exist );
// Only write the file if the folders exist.
if ( $dirs_exist ) {
global $wp_filesystem;
$wp_filesystem->put_contents( $this->new_file_path, $file_content, $this->chmod_file );
}
}
}
/**
* @since 3.0
*
* @return void
*/
public function append_file( $file_content ) {
if ( $this->has_permission ) {
if ( file_exists( $this->new_file_path ) ) {
$existing_content = $this->get_contents();
$file_content = $existing_content . $file_content;
}
$this->create_file( $file_content );
}
}
/**
* Combine an array of files into one
*
* @since 3.0
*
* @param array $file_names And array of file paths.
*
* @return void
*/
public function combine_files( $file_names ) {
if ( $this->has_permission ) {
$content = '';
foreach ( $file_names as $file_name ) {
$content .= $this->get_contents( $file_name ) . "\n";
}
$this->create_file( $content );
}
}
/**
* @since 3.0
*/
public function get_file_contents() {
$content = '';
if ( $this->has_permission ) {
$content = $this->get_contents();
}
return $content;
}
/**
* @since 3.0
*/
private function get_contents( $file = '' ) {
global $wp_filesystem;
if ( empty( $file ) ) {
$file = $this->new_file_path;
}
return $wp_filesystem->get_contents( $file );
}
/**
* @since 3.0
*
* @return void
*/
private function check_permission() {
$creds = $this->get_creds();
$this->has_permission = true;
if ( empty( $creds ) || ! WP_Filesystem( $creds ) ) {
// initialize the API - any problems and we exit
$this->show_error_message();
$this->has_permission = false;
}
}
/**
* @param true $dirs_exist
*
* @return void
*/
private function create_directories( &$dirs_exist ) {
global $wp_filesystem;
$needed_dirs = $this->get_needed_dirs();
foreach ( $needed_dirs as $_dir ) {
// Only check to see if the Dir exists upon creation failure. Less I/O this way.
if ( $wp_filesystem->mkdir( $_dir, $this->chmod_dir ) ) {
$index_path = $_dir . '/index.php';
$wp_filesystem->put_contents( $index_path, "<?php\n// Silence is golden.\n?>", $this->chmod_file );
} else {
$dirs_exist = $wp_filesystem->is_dir( $_dir );
}
}
}
/**
* @return string[]
*/
private function get_needed_dirs() {
$dir_names = explode( '/', $this->folder_name );
$needed_dirs = array();
$next_dir = '';
foreach ( $dir_names as $dir ) {
$next_dir .= '/' . $dir;
$needed_dirs[] = $this->uploads['basedir'] . $next_dir;
}
return $needed_dirs;
}
private function get_creds() {
if ( ! function_exists( 'get_filesystem_method' ) ) {
include_once ABSPATH . 'wp-admin/includes/file.php';
}
$access_type = get_filesystem_method();
if ( $access_type === 'direct' ) {
$creds = request_filesystem_credentials( site_url() . '/wp-admin/', '', false, false, array() );
} else {
$creds = $this->get_ftp_creds( $access_type );
}
return $creds;
}
/**
* @param string $type
*/
private function get_ftp_creds( $type ) {
$credentials = get_option(
'ftp_credentials',
array(
'hostname' => '',
'username' => '',
)
);
$credentials['hostname'] = defined( 'FTP_HOST' ) ? FTP_HOST : $credentials['hostname'];
$credentials['username'] = defined( 'FTP_USER' ) ? FTP_USER : $credentials['username'];
$credentials['password'] = defined( 'FTP_PASS' ) ? FTP_PASS : '';
// Check to see if we are setting the public/private keys for ssh.
$credentials['public_key'] = defined( 'FTP_PUBKEY' ) ? FTP_PUBKEY : '';
$credentials['private_key'] = defined( 'FTP_PRIKEY' ) ? FTP_PRIKEY : '';
// Sanitize the hostname, Some people might pass in odd-data.
// Strip any schemes off.
$credentials['hostname'] = preg_replace( '|\w+://|', '', $credentials['hostname'] );
if ( strpos( $credentials['hostname'], ':' ) ) {
list( $credentials['hostname'], $credentials['port'] ) = explode( ':', $credentials['hostname'], 2 );
if ( ! is_numeric( $credentials['port'] ) ) {
unset( $credentials['port'] );
}
} else {
unset( $credentials['port'] );
}
if ( ( defined( 'FTP_SSH' ) && FTP_SSH ) || ( defined( 'FS_METHOD' ) && 'ssh2' == FS_METHOD ) ) {
$credentials['connection_type'] = 'ssh';
} elseif ( ( defined( 'FTP_SSL' ) && FTP_SSL ) && 'ftpext' == $type ) {
// Only the FTP Extension understands SSL.
$credentials['connection_type'] = 'ftps';
} elseif ( ! isset( $credentials['connection_type'] ) ) {
// All else fails (And it's not defaulted to something else saved), Default to FTP.
$credentials['connection_type'] = 'ftp';
}
$has_creds = ( ! empty( $credentials['password'] ) && ! empty( $credentials['username'] ) && ! empty( $credentials['hostname'] ) );
$can_ssh = ( 'ssh' == $credentials['connection_type'] && ! empty( $credentials['public_key'] ) && ! empty( $credentials['private_key'] ) );
if ( $has_creds || $can_ssh ) {
$stored_credentials = $credentials;
if ( ! empty( $stored_credentials['port'] ) ) {
// Save port as part of hostname to simplify above code.
$stored_credentials['hostname'] .= ':' . $stored_credentials['port'];
}
unset( $stored_credentials['password'], $stored_credentials['port'], $stored_credentials['private_key'], $stored_credentials['public_key'] );
return $credentials;
}
return false;
}
/**
* @return void
*/
private function show_error_message() {
if ( ! empty( $this->error_message ) ) {
echo '<div class="message">' . esc_html( $this->error_message ) . '</div>';
}
}
}