|
@@ -115,12 +115,12 @@ discard block |
|
|
block discarded – undo |
|
115
|
115
|
public function duplicate_link_field_options( $field_options, $template_id, $field_id, $context, $input_type ) { |
|
116
|
116
|
|
|
117
|
117
|
// Always a link, never a filter, always same window |
|
118
|
|
- unset( $field_options['show_as_link'], $field_options['search_filter'], $field_options['new_window'] ); |
|
|
118
|
+ unset( $field_options[ 'show_as_link' ], $field_options[ 'search_filter' ], $field_options[ 'new_window' ] ); |
|
119
|
119
|
|
|
120
|
120
|
// Duplicate Entry link should only appear to visitors capable of editing entries |
|
121
|
|
- unset( $field_options['only_loggedin'], $field_options['only_loggedin_cap'] ); |
|
|
121
|
+ unset( $field_options[ 'only_loggedin' ], $field_options[ 'only_loggedin_cap' ] ); |
|
122
|
122
|
|
|
123
|
|
- $add_option['duplicate_link'] = array( |
|
|
123
|
+ $add_option[ 'duplicate_link' ] = array( |
|
124
|
124
|
'type' => 'text', |
|
125
|
125
|
'label' => __( 'Duplicate Link Text', 'gravityview' ), |
|
126
|
126
|
'desc' => NULL, |
|
@@ -128,7 +128,7 @@ discard block |
|
|
block discarded – undo |
|
128
|
128
|
'merge_tags' => true, |
|
129
|
129
|
); |
|
130
|
130
|
|
|
131
|
|
- $field_options['allow_duplicate_cap'] = array( |
|
|
131
|
+ $field_options[ 'allow_duplicate_cap' ] = array( |
|
132
|
132
|
'type' => 'select', |
|
133
|
133
|
'label' => __( 'Allow the following users to duplicate the entry:', 'gravityview' ), |
|
134
|
134
|
'choices' => GravityView_Render_Settings::get_cap_choices( $template_id, $field_id, $context, $input_type ), |
|
@@ -155,7 +155,7 @@ discard block |
|
|
block discarded – undo |
|
155
|
155
|
public function add_default_field( $entry_default_fields, $form = array(), $zone = '' ) { |
|
156
|
156
|
|
|
157
|
157
|
if ( 'edit' !== $zone ) { |
|
158
|
|
- $entry_default_fields['duplicate_link'] = array( |
|
|
158
|
+ $entry_default_fields[ 'duplicate_link' ] = array( |
|
159
|
159
|
'label' => __( 'Duplicate Entry', 'gravityview' ), |
|
160
|
160
|
'type' => 'duplicate_link', |
|
161
|
161
|
'desc' => __( 'A link to duplicate the entry. Respects the Duplicate Entry permissions.', 'gravityview' ), |
|
@@ -176,7 +176,7 @@ discard block |
|
|
block discarded – undo |
|
176
|
176
|
*/ |
|
177
|
177
|
public function add_available_field( $available_fields = array() ) { |
|
178
|
178
|
|
|
179
|
|
- $available_fields['duplicate_link'] = array( |
|
|
179
|
+ $available_fields[ 'duplicate_link' ] = array( |
|
180
|
180
|
'label_text' => __( 'Duplicate Entry', 'gravityview' ), |
|
181
|
181
|
'field_id' => 'duplicate_link', |
|
182
|
182
|
'label_type' => 'field', |
|
@@ -209,9 +209,9 @@ discard block |
|
|
block discarded – undo |
|
209
|
209
|
if ( 'duplicate_link' === $field_id ) { |
|
210
|
210
|
|
|
211
|
211
|
// Remove other built-in caps. |
|
212
|
|
- unset( $caps['publish_posts'], $caps['gravityforms_view_entries'], $caps['duplicate_others_posts'] ); |
|
|
212
|
+ unset( $caps[ 'publish_posts' ], $caps[ 'gravityforms_view_entries' ], $caps[ 'duplicate_others_posts' ] ); |
|
213
|
213
|
|
|
214
|
|
- $caps['read'] = _x( 'Entry Creator', 'User capability', 'gravityview' ); |
|
|
214
|
+ $caps[ 'read' ] = _x( 'Entry Creator', 'User capability', 'gravityview' ); |
|
215
|
215
|
} |
|
216
|
216
|
|
|
217
|
217
|
return $caps; |
|
@@ -246,7 +246,7 @@ discard block |
|
|
block discarded – undo |
|
246
|
246
|
*/ |
|
247
|
247
|
public static function get_duplicate_link( $entry, $view_id, $post_id = null ) { |
|
248
|
248
|
|
|
249
|
|
- $base = GravityView_API::directory_link( $post_id ? : $view_id, true ); |
|
|
249
|
+ $base = GravityView_API::directory_link( $post_id ?: $view_id, true ); |
|
250
|
250
|
|
|
251
|
251
|
if ( empty( $base ) ) { |
|
252
|
252
|
gravityview()->log->error( 'Post ID does not exist: {post_id}', array( 'post_id' => $post_id ) ); |
|
@@ -255,12 +255,12 @@ discard block |
|
|
block discarded – undo |
|
255
|
255
|
|
|
256
|
256
|
$actionurl = add_query_arg( array( |
|
257
|
257
|
'action' => 'duplicate', |
|
258
|
|
- 'entry_id' => $entry['id'], |
|
|
258
|
+ 'entry_id' => $entry[ 'id' ], |
|
259
|
259
|
'gvid' => $view_id, |
|
260
|
260
|
'view_id' => $view_id, |
|
261
|
261
|
), $base ); |
|
262
|
262
|
|
|
263
|
|
- return add_query_arg( 'duplicate', wp_create_nonce( self::get_nonce_key( $entry['id'] ) ), $actionurl ); |
|
|
263
|
+ return add_query_arg( 'duplicate', wp_create_nonce( self::get_nonce_key( $entry[ 'id' ] ) ), $actionurl ); |
|
264
|
264
|
} |
|
265
|
265
|
|
|
266
|
266
|
/** |
|
@@ -281,12 +281,12 @@ discard block |
|
|
block discarded – undo |
|
281
|
281
|
public function process_duplicate() { |
|
282
|
282
|
|
|
283
|
283
|
// If the form is submitted |
|
284
|
|
- if ( ( ! isset( $_GET['action'] ) ) || 'duplicate' !== $_GET['action'] || ( ! isset( $_GET['entry_id'] ) ) ) { |
|
|
284
|
+ if ( ( ! isset( $_GET[ 'action' ] ) ) || 'duplicate' !== $_GET[ 'action' ] || ( ! isset( $_GET[ 'entry_id' ] ) ) ) { |
|
285
|
285
|
return; |
|
286
|
286
|
} |
|
287
|
287
|
|
|
288
|
288
|
// Make sure it's a GravityView request |
|
289
|
|
- $valid_nonce_key = wp_verify_nonce( \GV\Utils::_GET( 'duplicate' ), self::get_nonce_key( $_GET['entry_id'] ) ); |
|
|
289
|
+ $valid_nonce_key = wp_verify_nonce( \GV\Utils::_GET( 'duplicate' ), self::get_nonce_key( $_GET[ 'entry_id' ] ) ); |
|
290
|
290
|
|
|
291
|
291
|
if ( ! $valid_nonce_key ) { |
|
292
|
292
|
gravityview()->log->debug( 'Duplicate entry not processed: nonce validation failed.' ); |
|
@@ -294,7 +294,7 @@ discard block |
|
|
block discarded – undo |
|
294
|
294
|
} |
|
295
|
295
|
|
|
296
|
296
|
// Get the entry slug |
|
297
|
|
- $entry_slug = esc_attr( $_GET['entry_id'] ); |
|
|
297
|
+ $entry_slug = esc_attr( $_GET[ 'entry_id' ] ); |
|
298
|
298
|
|
|
299
|
299
|
// See if there's an entry there |
|
300
|
300
|
$entry = gravityview_get_entry( $entry_slug, true, false ); |
|
@@ -388,15 +388,15 @@ discard block |
|
|
block discarded – undo |
|
388
|
388
|
return new WP_Error( 'gravityview-duplicate-entry-missing', __( 'The entry does not exist.', 'gravityview' ) ); |
|
389
|
389
|
} |
|
390
|
390
|
|
|
391
|
|
- $row['id'] = null; |
|
392
|
|
- $row['date_created'] = date( 'Y-m-d H:i:s', time() ); |
|
393
|
|
- $row['date_updated'] = $row['date_created']; |
|
394
|
|
- $row['is_starred'] = false; |
|
395
|
|
- $row['is_read'] = false; |
|
396
|
|
- $row['ip'] = GFFormsModel::get_ip(); |
|
397
|
|
- $row['source_url'] = esc_url_raw( remove_query_arg( array( 'action', 'gvid' ) ) ); |
|
398
|
|
- $row['user_agent'] = \GV\Utils::_SERVER( 'HTTP_USER_AGENT' ); |
|
399
|
|
- $row['created_by'] = wp_get_current_user()->ID; |
|
|
391
|
+ $row[ 'id' ] = null; |
|
|
392
|
+ $row[ 'date_created' ] = date( 'Y-m-d H:i:s', time() ); |
|
|
393
|
+ $row[ 'date_updated' ] = $row[ 'date_created' ]; |
|
|
394
|
+ $row[ 'is_starred' ] = false; |
|
|
395
|
+ $row[ 'is_read' ] = false; |
|
|
396
|
+ $row[ 'ip' ] = GFFormsModel::get_ip(); |
|
|
397
|
+ $row[ 'source_url' ] = esc_url_raw( remove_query_arg( array( 'action', 'gvid' ) ) ); |
|
|
398
|
+ $row[ 'user_agent' ] = \GV\Utils::_SERVER( 'HTTP_USER_AGENT' ); |
|
|
399
|
+ $row[ 'created_by' ] = wp_get_current_user()->ID; |
|
400
|
400
|
|
|
401
|
401
|
/** |
|
402
|
402
|
* @filter `gravityview/entry/duplicate/details` Modify the new entry details before it's created. |
|
@@ -424,15 +424,15 @@ discard block |
|
|
block discarded – undo |
|
424
|
424
|
|
|
425
|
425
|
$save_this_meta = array(); |
|
426
|
426
|
foreach ( $duplicate_meta->get_output() as $m ) { |
|
427
|
|
- $save_this_meta[] = array( |
|
428
|
|
- 'meta_key' => $m['meta_key'], |
|
429
|
|
- 'meta_value' => $m['meta_value'], |
|
430
|
|
- 'item_index' => $m['item_index'], |
|
|
427
|
+ $save_this_meta[ ] = array( |
|
|
428
|
+ 'meta_key' => $m[ 'meta_key' ], |
|
|
429
|
+ 'meta_value' => $m[ 'meta_value' ], |
|
|
430
|
+ 'item_index' => $m[ 'item_index' ], |
|
431
|
431
|
); |
|
432
|
432
|
} |
|
433
|
433
|
|
|
434
|
434
|
// Update the row ID for later usage |
|
435
|
|
- $row['id'] = $duplicated_id; |
|
|
435
|
+ $row[ 'id' ] = $duplicated_id; |
|
436
|
436
|
|
|
437
|
437
|
/** |
|
438
|
438
|
* @filter `gravityview/entry/duplicate/meta` Modify the new entry meta details. |
|
@@ -443,8 +443,8 @@ discard block |
|
|
block discarded – undo |
|
443
|
443
|
$save_this_meta = apply_filters( 'gravityview/entry/duplicate/meta', $save_this_meta, $row, $entry ); |
|
444
|
444
|
|
|
445
|
445
|
foreach ( $save_this_meta as $data ) { |
|
446
|
|
- $data['form_id'] = $entry['form_id']; |
|
447
|
|
- $data['entry_id'] = $duplicated_id; |
|
|
446
|
+ $data[ 'form_id' ] = $entry[ 'form_id' ]; |
|
|
447
|
+ $data[ 'entry_id' ] = $duplicated_id; |
|
448
|
448
|
|
|
449
|
449
|
if ( ! $wpdb->insert( $entry_meta_table, $data ) ) { |
|
450
|
450
|
return new WP_Error( 'gravityview-duplicate-entry-db-meta', __( 'There was an error duplicating the entry.', 'gravityview' ) ); |
|
@@ -478,13 +478,13 @@ discard block |
|
|
block discarded – undo |
|
478
|
478
|
public function verify_nonce() { |
|
479
|
479
|
|
|
480
|
480
|
// No duplicate entry request was made |
|
481
|
|
- if ( empty( $_GET['entry_id'] ) || empty( $_GET['duplicate'] ) ) { |
|
|
481
|
+ if ( empty( $_GET[ 'entry_id' ] ) || empty( $_GET[ 'duplicate' ] ) ) { |
|
482
|
482
|
return false; |
|
483
|
483
|
} |
|
484
|
484
|
|
|
485
|
|
- $nonce_key = self::get_nonce_key( $_GET['entry_id'] ); |
|
|
485
|
+ $nonce_key = self::get_nonce_key( $_GET[ 'entry_id' ] ); |
|
486
|
486
|
|
|
487
|
|
- $valid = wp_verify_nonce( $_GET['duplicate'], $nonce_key ); |
|
|
487
|
+ $valid = wp_verify_nonce( $_GET[ 'duplicate' ], $nonce_key ); |
|
488
|
488
|
|
|
489
|
489
|
/** |
|
490
|
490
|
* @filter `gravityview/duplicate-entry/verify_nonce` Override Duplicate Entry nonce validation. Return true to declare nonce valid. |
|
@@ -520,7 +520,7 @@ discard block |
|
|
block discarded – undo |
|
520
|
520
|
return ''; |
|
521
|
521
|
} |
|
522
|
522
|
|
|
523
|
|
- return 'return window.confirm(\''. esc_js( $confirm ) .'\');'; |
|
|
523
|
+ return 'return window.confirm(\'' . esc_js( $confirm ) . '\');'; |
|
524
|
524
|
} |
|
525
|
525
|
|
|
526
|
526
|
/** |
|
@@ -574,7 +574,7 @@ discard block |
|
|
block discarded – undo |
|
574
|
574
|
public static function check_user_cap_duplicate_entry( $entry, $field = array(), $view_id = 0 ) { |
|
575
|
575
|
$current_user = wp_get_current_user(); |
|
576
|
576
|
|
|
577
|
|
- $entry_id = isset( $entry['id'] ) ? $entry['id'] : null; |
|
|
577
|
+ $entry_id = isset( $entry[ 'id' ] ) ? $entry[ 'id' ] : null; |
|
578
|
578
|
|
|
579
|
579
|
// Or if they can duplicate any entries (as defined in Gravity Forms), we're good. |
|
580
|
580
|
if ( GVCommon::has_cap( array( 'gravityforms_edit_entries', 'gform_full_access', 'gravityview_full_access' ), $entry_id ) ) { |
|
@@ -589,17 +589,17 @@ discard block |
|
|
block discarded – undo |
|
589
|
589
|
if ( ! empty( $field ) ) { |
|
590
|
590
|
|
|
591
|
591
|
// If capability is not defined, something is not right! |
|
592
|
|
- if ( empty( $field['allow_duplicate_cap'] ) ) { |
|
|
592
|
+ if ( empty( $field[ 'allow_duplicate_cap' ] ) ) { |
|
593
|
593
|
|
|
594
|
594
|
gravityview()->log->error( 'Cannot read duplicate entry field caps', array( 'data' => $field ) ); |
|
595
|
595
|
|
|
596
|
596
|
return false; |
|
597
|
597
|
} |
|
598
|
598
|
|
|
599
|
|
- if ( GVCommon::has_cap( $field['allow_duplicate_cap'] ) ) { |
|
|
599
|
+ if ( GVCommon::has_cap( $field[ 'allow_duplicate_cap' ] ) ) { |
|
600
|
600
|
|
|
601
|
601
|
// Do not return true if cap is read, as we need to check if the current user created the entry |
|
602
|
|
- if ( 'read' !== $field['allow_duplicate_cap'] ) { |
|
|
602
|
+ if ( 'read' !== $field[ 'allow_duplicate_cap' ] ) { |
|
603
|
603
|
return true; |
|
604
|
604
|
} |
|
605
|
605
|
|
|
@@ -612,7 +612,7 @@ discard block |
|
|
block discarded – undo |
|
612
|
612
|
|
|
613
|
613
|
} |
|
614
|
614
|
|
|
615
|
|
- if ( ! isset( $entry['created_by'] ) ) { |
|
|
615
|
+ if ( ! isset( $entry[ 'created_by' ] ) ) { |
|
616
|
616
|
|
|
617
|
617
|
gravityview()->log->error( 'Cannot duplicate entry; entry `created_by` doesn\'t exist.' ); |
|
618
|
618
|
|
|
@@ -637,7 +637,7 @@ discard block |
|
|
block discarded – undo |
|
637
|
637
|
} |
|
638
|
638
|
|
|
639
|
639
|
// If the logged-in user is the same as the user who created the entry, we're good. |
|
640
|
|
- if ( is_user_logged_in() && intval( $current_user->ID ) === intval( $entry['created_by'] ) ) { |
|
|
640
|
+ if ( is_user_logged_in() && intval( $current_user->ID ) === intval( $entry[ 'created_by' ] ) ) { |
|
641
|
641
|
|
|
642
|
642
|
gravityview()->log->debug( 'User {user_id} created the entry.', array( 'user_id' => $current_user->ID ) ); |
|
643
|
643
|
|
|
@@ -661,12 +661,12 @@ discard block |
|
|
block discarded – undo |
|
661
|
661
|
* @return void |
|
662
|
662
|
*/ |
|
663
|
663
|
public function maybe_display_message( $current_view_id = 0 ) { |
|
664
|
|
- if ( empty( $_GET['status'] ) || ! self::verify_nonce() ) { |
|
|
664
|
+ if ( empty( $_GET[ 'status' ] ) || ! self::verify_nonce() ) { |
|
665
|
665
|
return; |
|
666
|
666
|
} |
|
667
|
667
|
|
|
668
|
668
|
// Entry wasn't duplicated from current View |
|
669
|
|
- if ( isset( $_GET['view_id'] ) && ( intval( $_GET['view_id'] ) !== intval( $current_view_id ) ) ) { |
|
|
669
|
+ if ( isset( $_GET[ 'view_id' ] ) && ( intval( $_GET[ 'view_id' ] ) !== intval( $current_view_id ) ) ) { |
|
670
|
670
|
return; |
|
671
|
671
|
} |
|
672
|
672
|
|
|
@@ -674,11 +674,11 @@ discard block |
|
|
block discarded – undo |
|
674
|
674
|
} |
|
675
|
675
|
|
|
676
|
676
|
public function display_message() { |
|
677
|
|
- if ( empty( $_GET['status'] ) || empty( $_GET['duplicate'] ) ) { |
|
|
677
|
+ if ( empty( $_GET[ 'status' ] ) || empty( $_GET[ 'duplicate' ] ) ) { |
|
678
|
678
|
return; |
|
679
|
679
|
} |
|
680
|
680
|
|
|
681
|
|
- $status = esc_attr( $_GET['status'] ); |
|
|
681
|
+ $status = esc_attr( $_GET[ 'status' ] ); |
|
682
|
682
|
$message_from_url = \GV\Utils::_GET( 'message' ); |
|
683
|
683
|
$message_from_url = rawurldecode( stripslashes_deep( $message_from_url ) ); |
|
684
|
684
|
$class = ''; |
|
@@ -704,7 +704,7 @@ discard block |
|
|
block discarded – undo |
|
704
|
704
|
$message = apply_filters( 'gravityview/duplicate-entry/message', esc_attr( $message ), $status, $message_from_url ); |
|
705
|
705
|
|
|
706
|
706
|
// DISPLAY ERROR/SUCCESS MESSAGE |
|
707
|
|
- echo '<div class="gv-notice' . esc_attr( $class ) .'">'. $message .'</div>'; |
|
|
707
|
+ echo '<div class="gv-notice' . esc_attr( $class ) . '">' . $message . '</div>'; |
|
708
|
708
|
} |
|
709
|
709
|
|
|
710
|
710
|
/** |
|
@@ -735,7 +735,7 @@ discard block |
|
|
block discarded – undo |
|
735
|
735
|
?> |
|
736
|
736
|
<span class="duplicate"> |
|
737
|
737
|
| |
|
738
|
|
- <a href="<?php echo wp_nonce_url( add_query_arg( 'entry_id', $entry['id'] ), self::get_nonce_key( $entry['id'] ), 'duplicate' ); ?>"><?php esc_html_e( 'Duplicate', 'gravityview' ); ?></a> |
|
|
738
|
+ <a href="<?php echo wp_nonce_url( add_query_arg( 'entry_id', $entry[ 'id' ] ), self::get_nonce_key( $entry[ 'id' ] ), 'duplicate' ); ?>"><?php esc_html_e( 'Duplicate', 'gravityview' ); ?></a> |
|
739
|
739
|
</span> |
|
740
|
740
|
<?php |
|
741
|
741
|
} |
|
@@ -757,9 +757,9 @@ discard block |
|
|
block discarded – undo |
|
757
|
757
|
|
|
758
|
758
|
if ( 'success' === \GV\Utils::_GET( 'result' ) ) { |
|
759
|
759
|
add_filter( 'gform_admin_messages', function( $messages ) { |
|
760
|
|
- $messages = (array) $messages; |
|
|
760
|
+ $messages = (array)$messages; |
|
761
|
761
|
|
|
762
|
|
- $messages[] = esc_html__( 'Entry duplicated.', 'gravityview' ); |
|
|
762
|
+ $messages[ ] = esc_html__( 'Entry duplicated.', 'gravityview' ); |
|
763
|
763
|
return $messages; |
|
764
|
764
|
} ); |
|
765
|
765
|
} |
|
@@ -770,7 +770,7 @@ discard block |
|
|
block discarded – undo |
|
770
|
770
|
|
|
771
|
771
|
$check_logs_message = ''; |
|
772
|
772
|
|
|
773
|
|
- if( $is_logging_active ) { |
|
|
773
|
+ if ( $is_logging_active ) { |
|
774
|
774
|
$check_logs_message = sprintf( ' <a href="%s">%s</a>', |
|
775
|
775
|
esc_url( admin_url( 'admin.php?page=gf_settings&subview=gravityformslogging' ) ), |
|
776
|
776
|
esc_html_x( 'Check the GravityView logs for more information.', 'Error message links to logging page', 'gravityview' ) |
|
@@ -778,9 +778,9 @@ discard block |
|
|
block discarded – undo |
|
778
|
778
|
} |
|
779
|
779
|
|
|
780
|
780
|
add_filter( 'gform_admin_error_messages', function( $messages ) use ( $check_logs_message ) { |
|
781
|
|
- $messages = (array) $messages; |
|
|
781
|
+ $messages = (array)$messages; |
|
782
|
782
|
|
|
783
|
|
- $messages[] = esc_html__( 'There was an error duplicating the entry.', 'gravityview' ) . $check_logs_message; |
|
|
783
|
+ $messages[ ] = esc_html__( 'There was an error duplicating the entry.', 'gravityview' ) . $check_logs_message; |
|
784
|
784
|
|
|
785
|
785
|
return $messages; |
|
786
|
786
|
} ); |