Sindbad~EG File Manager
<?php
/**
* @package Pods\Fields
*/
class PodsField_File extends PodsField {
/**
* {@inheritdoc}
*/
public static $group = 'Relationships / Media';
/**
* {@inheritdoc}
*/
public static $type = 'file';
/**
* {@inheritdoc}
*/
public static $label = 'File / Image / Video';
/**
* {@inheritdoc}
*/
protected static $api = false;
/**
* {@inheritdoc}
*/
public function setup() {
self::$label = __( 'File / Image / Video', 'pods' );
}
/**
* {@inheritdoc}
*/
public function admin_init() {
// Hook into AJAX for Uploads.
add_action( 'wp_ajax_pods_upload', array( $this, 'admin_ajax_upload' ) );
add_action( 'wp_ajax_nopriv_pods_upload', array( $this, 'admin_ajax_upload' ) );
}
/**
* {@inheritdoc}
*/
public function options() {
$sizes = get_intermediate_image_sizes();
$image_sizes = array();
foreach ( $sizes as $size ) {
$image_sizes[ $size ] = ucwords( str_replace( '-', ' ', $size ) );
}
$type = static::$type;
$options = array(
static::$type . '_format_type' => array(
'label' => __( 'Upload Limit', 'pods' ),
'default' => 'single',
'type' => 'pick',
'data' => array(
'single' => __( 'Single File', 'pods' ),
'multi' => __( 'Multiple Files', 'pods' ),
),
'dependency' => true,
),
static::$type . '_uploader' => array(
'label' => __( 'File Uploader', 'pods' ),
'default' => 'attachment',
'type' => 'pick',
'data' => apply_filters(
"pods_form_ui_field_{$type}_uploader_options",
array(
'attachment' => __( 'Upload and/or Select (Media Library)', 'pods' ),
'plupload' => __( 'Upload only (Plupload)', 'pods' ),
)
),
'dependency' => true,
),
static::$type . '_attachment_tab' => array(
'label' => __( 'Attachments Default Tab', 'pods' ),
'depends-on' => array( static::$type . '_uploader' => 'attachment' ),
'default' => 'upload',
'type' => 'pick',
'data' => array(
// These keys must match WP media modal router names.
'upload' => __( 'Upload File', 'pods' ),
'browse' => __( 'Media Library', 'pods' ),
),
),
static::$type . '_edit_title' => array(
'label' => __( 'Editable Title', 'pods' ),
'default' => 1,
'type' => 'boolean',
),
static::$type . '_show_edit_link' => array(
'label' => __( 'Show Edit Link', 'pods' ),
'default' => 0,
'type' => 'boolean',
),
static::$type . '_linked' => array(
'label' => __( 'Show Download Link', 'pods' ),
'default' => 0,
'type' => 'boolean',
),
static::$type . '_limit' => array(
'label' => __( 'Max Number of Files', 'pods' ),
'depends-on' => array( static::$type . '_format_type' => 'multi' ),
'default' => 0,
'type' => 'number',
),
static::$type . '_restrict_filesize' => array(
'label' => __( 'Restrict File Size', 'pods' ),
'help' => __( 'Valid size suffixes are: GB (gigabytes), MB (megabytes), KB (kilobytes), or B (bytes). Defaults to the <a href="https://developer.wordpress.org/reference/functions/wp_max_upload_size/">wp_max_upload_size</a> setting.', 'pods' ),
'depends-on' => array( static::$type . '_uploader' => 'plupload' ),
'default' => '10MB',
'type' => 'text',
),
static::$type . '_type' => array(
'label' => __( 'Restrict File Types', 'pods' ),
'default' => apply_filters( "pods_form_ui_field_{$type}_type_default", 'images' ),
'type' => 'pick',
'data' => apply_filters(
"pods_form_ui_field_{$type}_type_options",
array(
'images' => __( 'Images (jpg, jpeg, png, gif)', 'pods' ),
'video' => __( 'Video (mpg, mov, flv, mp4, etc..)', 'pods' ),
'audio' => __( 'Audio (mp3, m4a, wav, wma, etc..)', 'pods' ),
'text' => __( 'Text (txt, csv, tsv, rtx, etc..)', 'pods' ),
'any' => __( 'Any Type (no restriction)', 'pods' ),
'other' => __( 'Other (customize allowed extensions)', 'pods' ),
)
),
'dependency' => true,
),
static::$type . '_allowed_extensions' => array(
'label' => __( 'Allowed File Extensions', 'pods' ),
'description' => __( 'Separate file extensions with a comma (ex. jpg,png,mp4,mov)', 'pods' ),
'depends-on' => array( static::$type . '_type' => 'other' ),
'default' => apply_filters( "pods_form_ui_field_{$type}_extensions_default", '' ),
'type' => 'text',
),
static::$type . '_field_template' => array(
'label' => __( 'List Style', 'pods' ),
'help' => __( 'You can choose which style you would like the files to appear within the form.', 'pods' ),
'depends-on' => array( static::$type . '_type' => 'images' ),
'default' => apply_filters( "pods_form_ui_field_{$type}_template_default", 'rows' ),
'type' => 'pick',
'data' => apply_filters(
"pods_form_ui_field_{$type}_type_templates",
array(
'rows' => __( 'Rows', 'pods' ),
'tiles' => __( 'Tiles', 'pods' ),
)
),
),
static::$type . '_add_button' => array(
'label' => __( 'Add Button Text', 'pods' ),
'default' => __( 'Add File', 'pods' ),
'type' => 'text',
),
static::$type . '_modal_title' => array(
'label' => __( 'Modal Title', 'pods' ),
'depends-on' => array( static::$type . '_uploader' => 'attachment' ),
'default' => __( 'Attach a file', 'pods' ),
'type' => 'text',
),
static::$type . '_modal_add_button' => array(
'label' => __( 'Modal Add Button Text', 'pods' ),
'depends-on' => array( static::$type . '_uploader' => 'attachment' ),
'default' => __( 'Add File', 'pods' ),
'type' => 'text',
),
/* WP GALLERY OUTPUT */
static::$type . '_wp_gallery_output' => array(
'label' => __( 'Output as a WP Gallery', 'pods' ),
'help' => sprintf( __( '<a href="%s" target="_blank">Click here for more info</a>', 'pods' ), 'https://codex.wordpress.org/The_WordPress_Gallery' ),
'depends-on' => array( static::$type . '_type' => 'images' ),
'dependency' => true,
'type' => 'boolean',
),
static::$type . '_wp_gallery_link' => array(
'label' => __( 'Gallery image links', 'pods' ),
'depends-on' => array( static::$type . '_wp_gallery_output' => 1 ),
'type' => 'pick',
'data' => array(
'post' => __( 'Attachment Page', 'pods' ),
'file' => __( 'Media File', 'pods' ),
'none' => __( 'None', 'pods' ),
),
),
static::$type . '_wp_gallery_columns' => array(
'label' => __( 'Gallery image columns', 'pods' ),
'depends-on' => array( static::$type . '_wp_gallery_output' => 1 ),
'type' => 'pick',
'data' => array(
'1' => 1,
'2' => 2,
'3' => 3,
'4' => 4,
'5' => 5,
'6' => 6,
'7' => 7,
'8' => 8,
'9' => 9,
),
),
static::$type . '_wp_gallery_random_sort' => array(
'label' => __( 'Gallery randomized order', 'pods' ),
'depends-on' => array( static::$type . '_wp_gallery_output' => 1 ),
'type' => 'boolean',
),
static::$type . '_wp_gallery_size' => array(
'label' => __( 'Gallery image size', 'pods' ),
'depends-on' => array( static::$type . '_wp_gallery_output' => 1 ),
'type' => 'pick',
'data' => $this->data_image_sizes(),
),
);
return $options;
}
/**
* {@inheritdoc}
*/
public function schema( $options = null ) {
return false;
}
/**
* {@inheritdoc}
*/
public function display( $value = null, $name = null, $options = null, $pod = null, $id = null ) {
if ( ! empty( $options[ static::$type . '_wp_gallery_output' ] ) ) {
return $this->do_wp_gallery( $value, $options );
}
if ( is_array( $value ) && ! empty( $value ) ) {
if ( isset( $value['ID'] ) ) {
$value = wp_get_attachment_url( $value['ID'] );
} else {
$attachments = $value;
$value = array();
foreach ( $attachments as $v ) {
if ( ! is_array( $v ) ) {
$value[] = $v;
} elseif ( isset( $v['ID'] ) ) {
$value[] = wp_get_attachment_url( $v['ID'] );
}
}
$value = implode( ' ', $value );
}
}
return $value;
}
/**
* {@inheritdoc}
*/
public function input( $name, $value = null, $options = null, $pod = null, $id = null ) {
$options = (array) $options;
$type = pods_v( 'type', $options, static::$type );
$args = compact( array_keys( get_defined_vars() ) );
$args = (object) $args;
/**
* Access Checking
*/
$is_user_logged_in = is_user_logged_in();
$file_upload_requirements = array(
'disabled' => ( defined( 'PODS_DISABLE_FILE_UPLOAD' ) && true === PODS_DISABLE_FILE_UPLOAD ),
'require_login' => ( defined( 'PODS_UPLOAD_REQUIRE_LOGIN' ) && true === PODS_UPLOAD_REQUIRE_LOGIN && ! $is_user_logged_in ),
'require_login_cap' => ( defined( 'PODS_UPLOAD_REQUIRE_LOGIN' ) && is_string( PODS_UPLOAD_REQUIRE_LOGIN ) && ( ! $is_user_logged_in || ! current_user_can( PODS_UPLOAD_REQUIRE_LOGIN ) ) ),
);
$file_browser_requirements = array(
'disabled' => ( defined( 'PODS_DISABLE_FILE_BROWSER' ) && true === PODS_DISABLE_FILE_BROWSER ),
'require_login' => ( defined( 'PODS_FILES_REQUIRE_LOGIN' ) && true === PODS_FILES_REQUIRE_LOGIN && ! $is_user_logged_in ),
'require_login_cap' => ( defined( 'PODS_FILES_REQUIRE_LOGIN' ) && is_string( PODS_FILES_REQUIRE_LOGIN ) && ( ! $is_user_logged_in || ! current_user_can( PODS_FILES_REQUIRE_LOGIN ) ) ),
);
$file_upload_requirements = array_filter( $file_upload_requirements );
$file_browser_requirements = array_filter( $file_browser_requirements );
if ( ! empty( $file_upload_requirements ) && ! empty( $file_browser_requirements ) ) {
?>
<p><?php esc_html_e( 'You do not have access to upload / browse files. Contact your website admin to resolve.', 'pods' ); ?></p>
<?php
return;
}
wp_enqueue_script( 'pods-dfv' );
wp_enqueue_media();
// Ensure the media library is initialized
$this->render_input_script( $args );
// @todo: we're short-circuiting for prototyping above. The actions below will need to be woven in somehow.
/**
* $form_field_type . '_uploader' != attachment, plupload, media
* Run this action 'pods_form_ui_field_' . static::$type . '_uploader_' . static::$type . '_uploader'
* Run this action 'pods_form_ui_field_' . static::$type . '_uploader', static::$type . '_uploader'
* Pass these args $name, $value, $options, $pod, $id
*/
}
/**
* {@inheritdoc}
*/
public function build_dfv_field_options( $options, $args ) {
if ( ! is_admin() ) {
include_once ABSPATH . '/wp-admin/includes/template.php';
if ( is_multisite() ) {
include_once ABSPATH . '/wp-admin/includes/ms.php';
}
}
// Handle default template setting.
$file_field_template = pods_v( $args->type . '_field_template', $options, 'rows', true );
// Get which file types the field is limited to.
$limit_file_type = pods_v( $args->type . '_type', $options, 'images' );
// Non-image file types are forced to rows template right now.
if ( 'images' !== $limit_file_type ) {
$file_field_template = 'rows';
}
$options[ $args->type . '_field_template' ] = $file_field_template;
// Enforce limit.
$file_limit = 1;
if ( 'multi' === pods_v( $args->type . '_format_type', $options, 'single' ) ) {
$file_limit = (int) pods_v( $args->type . '_limit', $options, 0 );
if ( $file_limit < 0 ) {
$file_limit = 0;
}
}
$options[ $args->type . '_limit' ] = $file_limit;
// Build types and extensions to limit by.
if ( 'images' === $limit_file_type ) {
$limit_types = 'image';
$limit_extensions = 'jpg,jpeg,png,gif';
} elseif ( 'video' === $limit_file_type ) {
$limit_types = 'video';
$limit_extensions = 'mpg,mov,flv,mp4';
} elseif ( 'audio' === $limit_file_type ) {
$limit_types = 'audio';
$limit_extensions = 'mp3,m4a,wav,wma';
} elseif ( 'text' === $limit_file_type ) {
$limit_types = 'text';
$limit_extensions = 'txt,rtx,csv,tsv';
} elseif ( 'any' === $limit_file_type ) {
$limit_types = '';
$limit_extensions = '*';
} else {
$limit_types = pods_v( $args->type . '_allowed_extensions', $options, '', true );
$limit_extensions = $limit_types;
}
// Find and replace certain characters to properly split by commas.
$find = array(
' ',
'.',
"\n",
"\t",
';',
);
$replace = array(
'',
',',
',',
',',
);
$limit_types = trim( str_replace( $find, $replace, $limit_types ), ',' );
$limit_extensions = trim( str_replace( $find, $replace, $limit_extensions ), ',' );
$mime_types = wp_get_mime_types();
if ( ! in_array( $limit_file_type, array( 'images', 'video', 'audio', 'text', 'any' ), true ) ) {
$new_limit_types = array();
$limit_types = explode( ',', $limit_types );
foreach ( $limit_types as $k => $limit_type ) {
if ( isset( $mime_types[ $limit_type ] ) ) {
$mime = explode( '/', $mime_types[ $limit_type ] );
$mime = $mime[0];
if ( ! in_array( $mime, $new_limit_types, true ) ) {
$new_limit_types[] = $mime;
}
} else {
$found = false;
foreach ( $mime_types as $type => $mime ) {
if ( false !== strpos( $type, $limit_type ) ) {
$mime = explode( '/', $mime );
$mime = $mime[0];
if ( ! in_array( $mime, $new_limit_types, true ) ) {
$new_limit_types[] = $mime;
}
$found = true;
}
}
if ( ! $found ) {
$new_limit_types[] = $limit_type;
}
}//end if
}//end foreach
if ( ! empty( $new_limit_types ) ) {
$limit_types = implode( ',', $new_limit_types );
}
}//end if
$options['limit_types'] = $limit_types;
$options['limit_extensions'] = $limit_extensions;
$is_user_logged_in = is_user_logged_in();
// @todo test frontend media modal
if ( empty( $options[ static::$type . '_uploader' ] ) || ! is_admin() || ! $is_user_logged_in || ( ! current_user_can( 'upload_files' ) && ! current_user_can( 'edit_files' ) ) ) {
$options[ static::$type . '_uploader' ] = 'plupload';
}
// @todo: plupload specific options need accommodation
if ( 'plupload' === $options[ static::$type . '_uploader' ] ) {
wp_enqueue_script( 'plupload-all' );
if ( $is_user_logged_in ) {
$uid = 'user_' . get_current_user_id();
} else {
// @codingStandardsIgnoreLine
$uid = @session_id();
}
$pod_id = '0';
if ( is_object( $args->pod ) ) {
$pod_id = $args->pod->pod_id;
}
$uri_hash = wp_create_nonce( 'pods_uri_' . $_SERVER['REQUEST_URI'] );
$field_nonce = wp_create_nonce( 'pods_upload_' . $pod_id . '_' . $uid . '_' . $uri_hash . '_' . $options['id'] );
$options['plupload_init'] = array(
'runtimes' => 'html5,silverlight,flash,html4',
'url' => admin_url( 'admin-ajax.php?pods_ajax=1', 'relative' ),
'file_data_name' => 'Filedata',
'multiple_queues' => false,
'max_file_size' => wp_max_upload_size() . 'b',
'flash_swf_url' => includes_url( 'js/plupload/plupload.flash.swf' ),
'silverlight_xap_url' => includes_url( 'js/plupload/plupload.silverlight.xap' ),
'filters' => array(
array(
'title' => __( 'Allowed Files', 'pods' ),
'extensions' => '*',
),
),
'multipart' => true,
'urlstream_upload' => true,
'multipart_params' => array(
'_wpnonce' => $field_nonce,
'action' => 'pods_upload',
'method' => 'upload',
'pod' => $pod_id,
'field' => $options['id'],
'uri' => $uri_hash,
),
);
}//end if
return $options;
}
/**
* {@inheritdoc}
*/
public function build_dfv_field_attributes( $attributes, $args ) {
// Add template class.
$attributes['class'] .= ' pods-field-template-' . $args->options[ $args->type . '_field_template' ];
return $attributes;
}
/**
* {@inheritdoc}
*/
public function build_dfv_field_item_data( $args ) {
$data = array();
$title_editable = (int) pods_v( $args->type . '_edit_title', $args->options, 0 );
$value = $args->value;
if ( empty( $value ) ) {
$value = array();
} else {
$value = (array) $value;
}
foreach ( $value as $id ) {
$attachment = get_post( $id );
if ( empty( $attachment ) ) {
continue;
}
$icon = '';
// @todo Add access check
$edit_link = get_edit_post_link( $attachment->ID, 'raw' );
$link = get_permalink( $attachment->ID );
$download = wp_get_attachment_url( $attachment->ID );
$thumb = wp_get_attachment_image_src( $id, 'thumbnail', true );
if ( ! empty( $thumb[0] ) ) {
$icon = $thumb[0];
}
$title = $attachment->post_title;
if ( 0 === $title_editable ) {
$title = basename( $attachment->guid );
}
$data[] = array(
'id' => $id,
'icon' => $icon,
'name' => $title,
'edit_link' => $edit_link,
'link' => $link,
'download' => $download,
);
}//end foreach
return $data;
}
/**
* {@inheritdoc}
*/
public function validate( $value, $name = null, $options = null, $fields = null, $pod = null, $id = null, $params = null ) {
// @todo Check file size
// @todo Check file extensions
return true;
}
/**
* {@inheritdoc}
*/
public function save( $value, $id = null, $name = null, $options = null, $fields = null, $pod = null, $params = null ) {
if ( empty( self::$api ) ) {
self::$api = pods_api();
}
// Handle File title saving.
foreach ( $value as $id ) {
$title = false;
if ( is_array( $id ) ) {
if ( isset( $id['title'] ) && 0 < strlen( trim( $id['title'] ) ) ) {
$title = trim( $id['title'] );
}
if ( isset( $id['id'] ) ) {
$id = (int) $id['id'];
} else {
$id = 0;
}
}
if ( empty( $id ) ) {
continue;
}
$attachment_data = array();
// Update the title if set.
if ( false !== $title && 1 === (int) pods_v( static::$type . '_edit_title', $options, 0 ) ) {
$attachment_data['post_title'] = $title;
}
// Update attachment parent if it's not set yet and we're updating a post.
if ( ! empty( $params->id ) && ! empty( $pod['type'] ) && 'post_type' === $pod['type'] ) {
$attachment = get_post( $id );
if ( isset( $attachment->post_parent ) && 0 === (int) $attachment->post_parent ) {
$attachment_data['post_parent'] = (int) $params->id;
}
}
// Update the attachment if it the data array is not still empty.
if ( ! empty( $attachment_data ) ) {
$attachment_data['ID'] = $id;
self::$api->save_wp_object( 'media', $attachment_data );
}
}//end foreach
}
/**
* {@inheritdoc}
*/
public function ui( $id, $value, $name = null, $options = null, $fields = null, $pod = null ) {
if ( empty( $value ) ) {
return;
}
if ( ! empty( $value ) && isset( $value['ID'] ) ) {
$value = array( $value );
}
$type = static::$type;
$image_size = apply_filters( "pods_form_ui_field_{$type}_ui_image_size", 'thumbnail', $id, $value, $name, $options, $pod );
return $this->images( $id, $value, $name, $options, $pod, $image_size );
}
/**
* Return image(s) markup.
*
* @param int $id Item ID.
* @param mixed $value Field value.
* @param string $name Field name.
* @param array $options Field options.
* @param array $pod Pod options.
* @param string $image_size Image size.
*
* @return string
* @since 2.3.0
*/
public function images( $id, $value, $name = null, $options = null, $pod = null, $image_size = null ) {
$images = '';
if ( empty( $value ) || ! is_array( $value ) ) {
return $images;
}
foreach ( $value as $v ) {
$images .= pods_image( $v, $image_size );
}
return $images;
}
/**
* Data callback for Image Sizes.
*
* @param string $name The name of the field.
* @param string|array $value The value of the field.
* @param array $options Field options.
* @param array $pod Pod data.
* @param int $id Item ID.
*
* @return array
*
* @since 2.3.0
*/
public function data_image_sizes( $name = null, $value = null, $options = null, $pod = null, $id = null ) {
$data = array();
$image_sizes = get_intermediate_image_sizes();
foreach ( $image_sizes as $image_size ) {
$data[ $image_size ] = ucwords( str_replace( '-', ' ', $image_size ) );
}
return apply_filters( 'pods_form_ui_field_pick_data_image_sizes', $data, $name, $value, $options, $pod, $id );
}
/**
* Create a WP Gallery from the passed values (need to be attachments)
*
* @since 2.7.0
*
* @param string|array $value The value(s).
* @param array $options The field options.
*
* @return string
*/
public function do_wp_gallery( $value, $options ) {
$shortcode_args = array();
if ( ! empty( $options[ static::$type . '_wp_gallery_columns' ] ) ) {
$shortcode_args['columns'] = absint( $options[ static::$type . '_wp_gallery_columns' ] );
}
if ( ! empty( $options[ static::$type . '_wp_gallery_random_sort' ] ) ) {
$shortcode_args['orderby'] = 'rand';
}
if ( ! empty( $options[ static::$type . '_wp_gallery_link' ] ) ) {
$shortcode_args['link'] = $options[ static::$type . '_wp_gallery_link' ];
}
if ( ! empty( $options[ static::$type . '_wp_gallery_size' ] ) ) {
$shortcode_args['size'] = $options[ static::$type . '_wp_gallery_size' ];
}
if ( isset( $value['ID'] ) ) {
$shortcode_args['ids'] = $value['ID'];
} else {
$images = array();
foreach ( $value as $v ) {
if ( ! is_array( $v ) ) {
$images[] = (int) $v;
} elseif ( isset( $v['ID'] ) ) {
$images[] = (int) $v['ID'];
}
}
$shortcode_args['ids'] = implode( ',', $images );
}
if ( is_callable( 'gallery_shortcode' ) ) {
return gallery_shortcode( $shortcode_args );
} else {
$shortcode = '[gallery';
foreach ( $shortcode_args as $key => $shortcode_arg ) {
$shortcode .= ' ' . esc_attr( $key ) . '="' . esc_attr( $shortcode_arg ) . '"';
}
$shortcode .= ']';
return do_shortcode( $shortcode );
}
}
/**
* Handle file row output for uploaders
*
* @param array $attributes Field options.
* @param int $limit List limit.
* @param bool $editable Whether the items should be editable.
* @param null|int|string $id Item ID.
* @param null|string $icon Icon URL.
* @param null|string $name File name.
* @param bool $linked Whether the items should be linked.
* @param null|string $link Link URL.
*
* @return string
* @since 2.0.0
*
* @deprecated 2.7.0
*/
public function markup( $attributes, $limit = 1, $editable = true, $id = null, $icon = null, $name = null, $linked = false, $link = null ) {
_doing_it_wrong( 'PodsField_File::markup', esc_html__( 'This method has been deprecated and will be removed from Pods 3.0', 'pods' ), '2.7' );
// Preserve current file type.
$field_type = PodsForm::$field_type;
ob_start();
if ( empty( $id ) ) {
$id = '{{id}}';
}
if ( empty( $icon ) ) {
$icon = '{{icon}}';
}
if ( empty( $name ) ) {
$name = '{{name}}';
}
if ( empty( $link ) ) {
$link = '{{link}}';
}
$editable = (boolean) $editable;
$linked = (boolean) $linked;
?>
<li class="pods-file hidden" id="pods-file-<?php echo esc_attr( $id ); ?>">
<?php
// @codingStandardsIgnoreLine
echo PodsForm::field( $attributes['name'] . '[' . $id . '][id]', $id, 'hidden' );
?>
<ul class="pods-file-meta media-item">
<?php if ( 1 !== (int) $limit ) { ?>
<li class="pods-file-col pods-file-handle">Handle</li>
<?php } ?>
<li class="pods-file-col pods-file-icon">
<img class="pinkynail" src="<?php echo esc_url( $icon ); ?>" alt="Icon" />
</li>
<li class="pods-file-col pods-file-name">
<?php
if ( $editable ) {
// @codingStandardsIgnoreLine
echo PodsForm::field( $attributes['name'] . '[' . $id . '][title]', $name, 'text' );
} else {
echo esc_html( $name );
}
?>
</li>
<li class="pods-file-col pods-file-actions">
<ul>
<li class="pods-file-col pods-file-delete"><a href="#delete">Delete</a></li>
<?php
if ( $linked ) {
?>
<li class="pods-file-col pods-file-download">
<a href="<?php echo esc_url( $link ); ?>" target="_blank">Download</a></li>
<?php
}
?>
</ul>
</li>
</ul>
</li>
<?php
PodsForm::$field_type = $field_type;
return ob_get_clean();
}
/**
* Handle AJAX plupload calls.
*
* @since 2.3.0
*/
public function admin_ajax_upload() {
pods_session_start();
// Sanitize input @codingStandardsIgnoreLine
$params = pods_unslash( (array) $_POST );
foreach ( $params as $key => $value ) {
if ( 'action' === $key ) {
continue;
}
unset( $params[ $key ] );
$params[ str_replace( '_podsfix_', '', $key ) ] = $value;
}
$params = (object) $params;
$methods = array(
'upload',
);
if ( ! isset( $params->method ) || ! in_array( $params->method, $methods, true ) || ! isset( $params->pod ) || ! isset( $params->field ) || ! isset( $params->uri ) || empty( $params->uri ) ) {
pods_error( 'Invalid AJAX request', PodsInit::$admin );
} elseif ( ! empty( $params->pod ) && empty( $params->field ) ) {
pods_error( 'Invalid AJAX request', PodsInit::$admin );
} elseif ( empty( $params->pod ) && ! current_user_can( 'upload_files' ) ) {
pods_error( 'Invalid AJAX request', PodsInit::$admin );
}
// Flash often fails to send cookies with the POST or upload, so we need to pass it in GET or POST instead
// @codingStandardsIgnoreLine
if ( is_ssl() && empty( $_COOKIE[ SECURE_AUTH_COOKIE ] ) && ! empty( $_REQUEST['auth_cookie'] ) ) {
// @codingStandardsIgnoreLine
$_COOKIE[ SECURE_AUTH_COOKIE ] = $_REQUEST['auth_cookie'];
// @codingStandardsIgnoreLine
} elseif ( empty( $_COOKIE[ AUTH_COOKIE ] ) && ! empty( $_REQUEST['auth_cookie'] ) ) {
// @codingStandardsIgnoreLine
$_COOKIE[ AUTH_COOKIE ] = $_REQUEST['auth_cookie'];
}
// @codingStandardsIgnoreLine
if ( empty( $_COOKIE[ LOGGED_IN_COOKIE ] ) && ! empty( $_REQUEST['logged_in_cookie'] ) ) {
// @codingStandardsIgnoreLine
$_COOKIE[ LOGGED_IN_COOKIE ] = $_REQUEST['logged_in_cookie'];
}
global $current_user;
unset( $current_user );
/**
* Access Checking
*/
$upload_disabled = false;
$is_user_logged_in = is_user_logged_in();
if ( defined( 'PODS_DISABLE_FILE_UPLOAD' ) && true === PODS_DISABLE_FILE_UPLOAD ) {
$upload_disabled = true;
} elseif ( ! $is_user_logged_in && defined( 'PODS_UPLOAD_REQUIRE_LOGIN' ) ) {
if ( true === PODS_UPLOAD_REQUIRE_LOGIN ) {
$upload_disabled = true;
} elseif ( is_string( PODS_UPLOAD_REQUIRE_LOGIN ) && ! current_user_can( PODS_UPLOAD_REQUIRE_LOGIN ) ) {
$upload_disabled = true;
}
}
$uid = @session_id();
if ( $is_user_logged_in ) {
$uid = 'user_' . get_current_user_id();
}
$nonce_check = 'pods_upload_' . (int) $params->pod . '_' . $uid . '_' . $params->uri . '_' . (int) $params->field;
if ( true === $upload_disabled || ! isset( $params->_wpnonce ) || false === wp_verify_nonce( $params->_wpnonce, $nonce_check ) ) {
pods_error( __( 'Unauthorized request', 'pods' ), PodsInit::$admin );
}
$pod = array();
$field = array(
'type' => 'file',
'options' => array(),
);
if ( empty( self::$api ) ) {
self::$api = pods_api();
}
self::$api->display_errors = false;
if ( ! empty( $params->pod ) ) {
$pod = self::$api->load_pod( array( 'id' => (int) $params->pod ) );
$field = self::$api->load_field( array( 'id' => (int) $params->field ) );
if ( empty( $pod ) || empty( $field ) || (int) $pod['id'] !== (int) $field['pod_id'] || ! isset( $pod['fields'][ $field['name'] ] ) ) {
pods_error( __( 'Invalid field request', 'pods' ), PodsInit::$admin );
}
if ( ! in_array( $field['type'], PodsForm::file_field_types(), true ) ) {
pods_error( __( 'Invalid field', 'pods' ), PodsInit::$admin );
}
}
$method = $params->method;
// Cleaning up $params
unset( $params->action, $params->method, $params->_wpnonce );
$params->post_id = (int) pods_v( 'post_id', $params, 0 );
/**
* Upload a new file (advanced - returns URL and ID)
*/
if ( 'upload' === $method ) {
$file = $_FILES['Filedata'];
$limit_size = pods_v( $field['type'] . '_restrict_filesize', $field['options'] );
if ( ! empty( $limit_size ) ) {
if ( false !== stripos( $limit_size, 'GB' ) ) {
$limit_size = (float) trim( str_ireplace( 'GB', '', $limit_size ) );
$limit_size = $limit_size * 1025 * 1025 * 1025;
// convert to MB to KB to B
} elseif ( false !== stripos( $limit_size, 'MB' ) ) {
$limit_size = (float) trim( str_ireplace( 'MB', '', $limit_size ) );
$limit_size = $limit_size * 1025 * 1025;
// convert to KB to B
} elseif ( false !== stripos( $limit_size, 'KB' ) ) {
$limit_size = (float) trim( str_ireplace( 'KB', '', $limit_size ) );
$limit_size *= 1025;
// convert to B
} elseif ( false !== stripos( $limit_size, 'B' ) ) {
$limit_size = (float) trim( str_ireplace( 'B', '', $limit_size ) );
} else {
$limit_size = wp_max_upload_size();
}
if ( 0 < $limit_size && $limit_size < $file['size'] ) {
$error = __( 'File size too large, max size is %s', 'pods' );
$error = sprintf( $error, pods_v( $field['type'] . '_restrict_filesize', $field['options'] ) );
pods_error( '<div style="color:#FF0000">Error: ' . $error . '</div>' );
}
}//end if
$limit_file_type = pods_v( $field['type'] . '_type', $field['options'], 'images' );
if ( 'images' === $limit_file_type ) {
$limit_types = 'jpg,jpeg,png,gif';
} elseif ( 'video' === $limit_file_type ) {
$limit_types = 'mpg,mov,flv,mp4';
} elseif ( 'audio' === $limit_file_type ) {
$limit_types = 'mp3,m4a,wav,wma';
} elseif ( 'text' === $limit_file_type ) {
$limit_types = 'txt,rtx,csv,tsv';
} elseif ( 'any' === $limit_file_type ) {
$limit_types = '';
} else {
$limit_types = pods_v( $field['type'] . '_allowed_extensions', $field['options'], '', true );
}
$limit_types = trim(
str_replace(
array( ' ', '.', "\n", "\t", ';' ), array(
'',
',',
',',
',',
), $limit_types
), ','
);
$mime_types = wp_get_mime_types();
if ( in_array( $limit_file_type, array( 'images', 'audio', 'video' ), true ) ) {
$new_limit_types = array();
foreach ( $mime_types as $type => $mime ) {
if ( 0 === strpos( $mime, $limit_file_type ) ) {
$type = explode( '|', $type );
$new_limit_types = array_merge( $new_limit_types, $type );
}
}
if ( ! empty( $new_limit_types ) ) {
$limit_types = implode( ',', $new_limit_types );
}
} elseif ( 'any' !== $limit_file_type ) {
$new_limit_types = array();
$limit_types = explode( ',', $limit_types );
foreach ( $limit_types as $k => $limit_type ) {
$found = false;
foreach ( $mime_types as $type => $mime ) {
if ( 0 === strpos( $mime, $limit_type ) ) {
$type = explode( '|', $type );
foreach ( $type as $t ) {
if ( ! in_array( $t, $new_limit_types, true ) ) {
$new_limit_types[] = $t;
}
}
$found = true;
}
}
if ( ! $found ) {
$new_limit_types[] = $limit_type;
}
}//end foreach
if ( ! empty( $new_limit_types ) ) {
$limit_types = implode( ',', $new_limit_types );
}
}//end if
$limit_types = explode( ',', $limit_types );
$limit_types = array_filter( array_unique( $limit_types ) );
if ( ! empty( $limit_types ) ) {
$ok = false;
foreach ( $limit_types as $limit_type ) {
$limit_type = '.' . trim( $limit_type, ' .' );
$pos = ( strlen( $file['name'] ) - strlen( $limit_type ) );
if ( stripos( $file['name'], $limit_type ) === $pos ) {
$ok = true;
break;
}
}
if ( false === $ok ) {
$error = __( 'File type not allowed, please use one of the following: %s', 'pods' );
$error = sprintf( $error, '.' . implode( ', .', $limit_types ) );
pods_error( '<div style="color:#FF0000">Error: ' . $error . '</div>' );
}
}//end if
$custom_handler = apply_filters( 'pods_upload_handle', null, 'Filedata', $params->post_id, $params, $field );
if ( null === $custom_handler ) {
$attachment_id = media_handle_upload( 'Filedata', $params->post_id );
if ( is_object( $attachment_id ) ) {
$errors = array();
foreach ( $attachment_id->errors['upload_error'] as $error_code => $error_message ) {
$errors[] = '[' . $error_code . '] ' . $error_message;
}
pods_error( '<div style="color:#FF0000">Error: ' . implode( '</div><div>', $errors ) . '</div>' );
} else {
$attachment = get_post( $attachment_id, ARRAY_A );
$attachment['filename'] = basename( $attachment['guid'] );
$thumb = wp_get_attachment_image_src( $attachment['ID'], 'thumbnail', true );
$attachment['thumbnail'] = '';
if ( ! empty( $thumb[0] ) ) {
$attachment['thumbnail'] = $thumb[0];
}
$attachment['link'] = get_permalink( $attachment['ID'] );
$attachment['edit_link'] = get_edit_post_link( $attachment['ID'] );
$attachment['download'] = wp_get_attachment_url( $attachment['ID'] );
$attachment = apply_filters( 'pods_upload_attachment', $attachment, $params->post_id );
wp_send_json( $attachment );
}//end if
}//end if
}//end if
die();
// KBAI!
}
}
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists