Passed
Push — ci ( 9342ca...3ea26a )
by litefeel
02:42
created
lib/post.php 2 patches
Indentation   +476 added lines, -476 removed lines patch added patch discarded remove patch
@@ -9,480 +9,480 @@
 block discarded – undo
9 9
  */
10 10
 class Writing_On_GitHub_Post {
11 11
 
12
-    /**
13
-     * Api object
14
-     *
15
-     * @var Writing_On_GitHub_Api
16
-     */
17
-    public $api;
18
-
19
-    /**
20
-     * Post ID
21
-     * @var integer
22
-     */
23
-    public $id = 0;
24
-
25
-    /**
26
-     * Blob object
27
-     * @var Writing_On_GitHub_Blob
28
-     */
29
-    public $blob;
30
-
31
-    /**
32
-     * Post object
33
-     * @var WP_Post
34
-     */
35
-    public $post;
36
-
37
-    /**
38
-     * Post args.
39
-     *
40
-     * @var array
41
-     */
42
-    protected $args;
43
-
44
-    /**
45
-     * Post meta.
46
-     *
47
-     * @var array
48
-     */
49
-    protected $meta;
50
-
51
-    /**
52
-     * Whether the post has been saved.
53
-     *
54
-     * @var bool
55
-     */
56
-    protected $new = true;
57
-
58
-
59
-    protected $old_github_path;
60
-
61
-    /**
62
-     * Instantiates a new Post object
63
-     *
64
-     * @param int|array                 $id_or_args Either a post ID or an array of arguments.
65
-     * @param Writing_On_GitHub_Api $api API object.
66
-     *
67
-     * @todo remove database operations from this method
68
-     */
69
-    public function __construct( $id_or_args, Writing_On_GitHub_Api $api ) {
70
-        $this->api = $api;
71
-
72
-        if ( is_numeric( $id_or_args ) ) {
73
-            $this->id   = (int) $id_or_args;
74
-            $this->post = get_post( $this->id );
75
-            $this->new  = false;
76
-        }
77
-
78
-        if ( is_array( $id_or_args ) ) {
79
-            $this->args = $id_or_args;
80
-
81
-            if ( isset( $this->args['ID'] ) ) {
82
-                $this->post = get_post( $this->args['ID'] );
83
-
84
-                if ( $this->post ) {
85
-                    $this->id  = $this->post->ID;
86
-                    $this->new = false;
87
-                } else {
88
-                    unset( $this->args['ID'] );
89
-                }
90
-            }
91
-        }
92
-    }
93
-
94
-    public function id() {
95
-        return $this->id;
96
-    }
97
-
98
-    /**
99
-     * Returns the post type
100
-     */
101
-    public function type() {
102
-        return $this->post->post_type;
103
-    }
104
-
105
-    /**
106
-     * Returns the post type
107
-     */
108
-    public function status() {
109
-        return $this->post->post_status;
110
-    }
111
-
112
-    /**
113
-     * Returns the post name
114
-     */
115
-    public function name() {
116
-        return $this->post->post_name;
117
-    }
118
-
119
-    /**
120
-     * Returns true if the post has a password
121
-     * @return bool
122
-     */
123
-    public function has_password() {
124
-        return ! empty( $this->post->post_password );
125
-    }
126
-
127
-    /**
128
-     * Combines the 2 content parts for GitHub
129
-     */
130
-    public function github_content() {
131
-        $use_blob = wogh_is_dont_export_content() && $this->blob;
132
-        $content = $use_blob ?
133
-            $this->blob->post_content() :
134
-            $this->post_content();
135
-
136
-        return $this->front_matter() . $content;
137
-        // $content = $this->front_matter() . $content;
138
-        // $ending  = apply_filters( 'wogh_line_endings', "\n" );
139
-
140
-        // return preg_replace( '~(*BSR_ANYCRLF)\R~', $ending, $content );
141
-    }
142
-
143
-    /**
144
-     * The post's YAML frontmatter
145
-     *
146
-     * Returns String the YAML frontmatter, ready to be written to the file
147
-     */
148
-    public function front_matter() {
149
-        return "---\n" . spyc_dump( $this->meta() ) . "---\n";
150
-    }
151
-
152
-    /**
153
-     * Returns the post_content
154
-     *
155
-     * Markdownify's the content if applicable
156
-     */
157
-    public function post_content() {
158
-        $content = $this->post->post_content;
159
-
160
-        if ( function_exists( 'wpmarkdown_html_to_markdown' ) ) {
161
-            $content = wpmarkdown_html_to_markdown( $content );
162
-        } else if ( class_exists( 'WPCom_Markdown' ) ) {
163
-            if ( WPCom_Markdown::get_instance()->is_markdown( $this->post->ID ) ) {
164
-                $content = $this->post->post_content_filtered;
165
-            }
166
-        }
167
-
168
-        return apply_filters( 'wogh_content_export', $content, $this );
169
-    }
170
-
171
-    public function old_github_path() {
172
-        return $this->old_github_path;
173
-    }
174
-
175
-    public function set_old_github_path( $path ) {
176
-        $this->old_github_path = $path;
177
-        update_post_meta( $this->id, '_wogh_github_path', $path );
178
-    }
179
-
180
-
181
-    /**
182
-     * Retrieves or calculates the proper GitHub path for a given post
183
-     *
184
-     * Returns (string) the path relative to repo root
185
-     */
186
-    public function github_path() {
187
-        $path = $this->github_directory() . $this->github_filename();
188
-
189
-        return $path;
190
-    }
191
-
192
-    /**
193
-     * Get GitHub directory based on post
194
-     *
195
-     * @return string
196
-     */
197
-    public function github_directory() {
198
-        if ( 'publish' !== $this->status() ) {
199
-            return apply_filters( 'wogh_directory_unpublished', '_drafts/', $this );
200
-        }
201
-
202
-        $name = '';
203
-
204
-        switch ( $this->type() ) {
205
-            case 'post':
206
-                $name = 'posts';
207
-                break;
208
-            case 'page':
209
-                $name = 'pages';
210
-                break;
211
-            default:
212
-                $obj = get_post_type_object( $this->type() );
213
-
214
-                if ( $obj ) {
215
-                    $name = strtolower( $obj->labels->name );
216
-                }
217
-
218
-                if ( ! $name ) {
219
-                    $name = '';
220
-                }
221
-        }
222
-
223
-        if ( $name ) {
224
-            $name = '_' . $name . '/';
225
-        }
226
-
227
-        return apply_filters( 'wogh_directory_published', $name, $this );
228
-    }
229
-
230
-    /**
231
-     * Build GitHub filename based on post
232
-     */
233
-    public function github_filename() {
234
-        if ( 'post' === $this->type() ) {
235
-            $filename = get_the_time( 'Y-m-d-', $this->id ) . $this->get_name() . '.md';
236
-        } else {
237
-            $filename = $this->get_name() . '.md';
238
-        }
239
-
240
-        return apply_filters( 'wogh_filename', $filename, $this );
241
-    }
242
-
243
-    /**
244
-     * Returns a post slug we can use in the GitHub filename
245
-     *
246
-     * @return string
247
-     */
248
-    protected function get_name() {
249
-        if ( '' !== $this->name() ) {
250
-            return $this->name();
251
-        }
252
-
253
-        return sanitize_title( get_the_title( $this->post ) );
254
-    }
255
-
256
-    /**
257
-     * is put on github
258
-     * @return boolean
259
-     */
260
-    public function is_on_github() {
261
-        $sha = get_post_meta( $this->id, '_wogh_sha', true );
262
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
263
-        if ( $sha && $github_path ) {
264
-            return true;
265
-        }
266
-        return false;
267
-    }
268
-
269
-    /**
270
-     * Returns the URL for the post on GitHub.
271
-     *
272
-     * @return string
273
-     */
274
-    public function github_view_url() {
275
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
276
-        $repository = $this->api->fetch()->repository();
277
-        $branch = $this->api->fetch()->branch();
278
-
279
-        return "https://github.com/$repository/blob/$branch/$github_path";
280
-    }
281
-
282
-    /**
283
-     * Returns the URL for the post on GitHub.
284
-     *
285
-     * @return string
286
-     */
287
-    public function github_edit_url() {
288
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
289
-        $repository = $this->api->fetch()->repository();
290
-        $branch = $this->api->fetch()->branch();
291
-
292
-        return "https://github.com/$repository/edit/$branch/$github_path";
293
-    }
294
-
295
-    /**
296
-     * Retrieve post type directory from blob path.
297
-     *
298
-     * @param string $path Path string.
299
-     *
300
-     * @return string
301
-     */
302
-    public function get_directory_from_path( $path ) {
303
-        $directory = explode( '/', $path );
304
-        $directory = count( $directory ) > 0 ? $directory[0] : '';
305
-
306
-        return $directory;
307
-    }
308
-
309
-    /**
310
-     * Determines the last author to modify the post
311
-     *
312
-     * Returns Array an array containing the author name and email
313
-     */
314
-    public function last_modified_author() {
315
-        if ( $last_id = get_post_meta( $this->id, '_edit_last', true ) ) {
316
-            $user = get_userdata( $last_id );
317
-
318
-            if ( $user ) {
319
-                return array( 'name' => $user->display_name, 'email' => $user->user_email );
320
-            }
321
-        }
322
-
323
-        return array();
324
-    }
325
-
326
-    /**
327
-     * The post's sha
328
-     * Cached as post meta, or will make a live call if need be
329
-     *
330
-     * Returns String the sha1 hash
331
-     */
332
-    public function sha() {
333
-        $sha = get_post_meta( $this->id, '_wogh_sha', true );
334
-
335
-        // If we've done a full export and we have no sha
336
-        // then we should try a live check to see if it exists.
337
-        // if ( ! $sha && 'yes' === get_option( '_wogh_fully_exported' ) ) {
338
-
339
-        //  // @todo could we eliminate this by calling down the full tree and searching it
340
-        //  $data = $this->api->fetch()->remote_contents( $this );
341
-
342
-        //  if ( ! is_wp_error( $data ) ) {
343
-        //      update_post_meta( $this->id, '_wogh_sha', $data->sha );
344
-        //      $sha = $data->sha;
345
-        //  }
346
-        // }
347
-
348
-        // if the sha still doesn't exist, then it's empty
349
-        if ( ! $sha || is_wp_error( $sha ) ) {
350
-            $sha = '';
351
-        }
352
-
353
-        return $sha;
354
-    }
355
-
356
-    /**
357
-     * Save the sha to post
358
-     *
359
-     * @param string $sha
360
-     */
361
-    public function set_sha( $sha ) {
362
-        update_post_meta( $this->id, '_wogh_sha', $sha );
363
-    }
364
-
365
-    /**
366
-     * The post's metadata
367
-     *
368
-     * Returns Array the post's metadata
369
-     */
370
-    public function meta() {
371
-        $meta = array(
372
-            'ID'           => $this->id,
373
-            'post_title'   => get_the_title( $this->post ),
374
-            'post_name'    => $this->post->post_name,
375
-            'author'       => ( $author = get_userdata( $this->post->post_author ) ) ? $author->display_name : '',
376
-            'post_date'    => $this->post->post_date,
377
-            'post_excerpt' => $this->post->post_excerpt,
378
-            'layout'       => get_post_type( $this->post ),
379
-            'link'         => get_permalink( $this->post ),
380
-            'published'    => 'publish' === $this->status() ? true : false,
381
-            'tags'         => wp_get_post_tags( $this->id, array( 'fields' => 'names' ) ),
382
-            'categories'   => wp_get_post_categories( $this->id, array( 'fields' => 'names' ) )
383
-        );
384
-        if ( empty($this->post->post_name) ) {
385
-            unset($meta['post_name']);
386
-        }
387
-        if ( empty($this->post->post_excerpt) ) {
388
-            unset($meta['post_excerpt']);
389
-        }
390
-        if ( 'yes' == get_option('wogh_ignore_author') ) {
391
-            unset($meta['author']);
392
-        }
393
-
394
-        //convert traditional post_meta values, hide hidden values, skip already populated values
395
-        // foreach ( get_post_custom( $this->id ) as $key => $value ) {
396
-
397
-        //  if ( '_' === substr( $key, 0, 1 ) || isset( $meta[ $key ] ) ) {
398
-        //      continue;
399
-        //  }
400
-
401
-        //  $meta[ $key ] = $value;
402
-
403
-        // }
404
-
405
-        return apply_filters( 'wogh_post_meta', $meta, $this );
406
-    }
407
-
408
-    /**
409
-     * Returns whether the Post has been saved in the DB yet.
410
-     *
411
-     * @return bool
412
-     */
413
-    public function is_new() {
414
-        return $this->new;
415
-    }
416
-
417
-    /**
418
-     * Sets the Post's meta.
419
-     *
420
-     * @param array $meta
421
-     */
422
-    public function set_meta( $meta ) {
423
-        $this->meta = $meta;
424
-    }
425
-
426
-    /**
427
-     * Returns the Post's arguments.
428
-     *
429
-     * @return array
430
-     */
431
-    public function get_args() {
432
-        return $this->args;
433
-    }
434
-
435
-    /**
436
-     * Returns the Post's meta.
437
-     *
438
-     * @return array
439
-     */
440
-    public function get_meta() {
441
-        return $this->meta;
442
-    }
443
-
444
-    /**
445
-     * Get the blob
446
-     * @return Writing_On_GitHub_Blob
447
-     */
448
-    public function get_blob() {
449
-        return $this->blob;
450
-    }
451
-
452
-    /**
453
-     * Set the blob
454
-     * @param Writing_On_GitHub_Blob $blob
455
-     */
456
-    public function set_blob( Writing_On_GitHub_Blob $blob ) {
457
-        $this->blob = $blob;
458
-    }
459
-
460
-    /**
461
-     * Sets the Post's WP_Post object.
462
-     *
463
-     * @param WP_Post $post
464
-     *
465
-     * @return $this
466
-     */
467
-    public function set_post( WP_Post $post ) {
468
-        $this->post = $post;
469
-        $this->id   = $post->ID;
470
-
471
-        return $this;
472
-    }
473
-
474
-    /**
475
-     * Transforms the Post into a Blob.
476
-     *
477
-     * @return Writing_On_GitHub_Blob
478
-     */
479
-    public function to_blob() {
480
-        $data = new stdClass;
481
-
482
-        $data->path    = $this->github_path();
483
-        $data->content = $this->github_content();
484
-        $data->sha     = $this->sha();
485
-
486
-        return new Writing_On_GitHub_Blob( $data );
487
-    }
12
+	/**
13
+	 * Api object
14
+	 *
15
+	 * @var Writing_On_GitHub_Api
16
+	 */
17
+	public $api;
18
+
19
+	/**
20
+	 * Post ID
21
+	 * @var integer
22
+	 */
23
+	public $id = 0;
24
+
25
+	/**
26
+	 * Blob object
27
+	 * @var Writing_On_GitHub_Blob
28
+	 */
29
+	public $blob;
30
+
31
+	/**
32
+	 * Post object
33
+	 * @var WP_Post
34
+	 */
35
+	public $post;
36
+
37
+	/**
38
+	 * Post args.
39
+	 *
40
+	 * @var array
41
+	 */
42
+	protected $args;
43
+
44
+	/**
45
+	 * Post meta.
46
+	 *
47
+	 * @var array
48
+	 */
49
+	protected $meta;
50
+
51
+	/**
52
+	 * Whether the post has been saved.
53
+	 *
54
+	 * @var bool
55
+	 */
56
+	protected $new = true;
57
+
58
+
59
+	protected $old_github_path;
60
+
61
+	/**
62
+	 * Instantiates a new Post object
63
+	 *
64
+	 * @param int|array                 $id_or_args Either a post ID or an array of arguments.
65
+	 * @param Writing_On_GitHub_Api $api API object.
66
+	 *
67
+	 * @todo remove database operations from this method
68
+	 */
69
+	public function __construct( $id_or_args, Writing_On_GitHub_Api $api ) {
70
+		$this->api = $api;
71
+
72
+		if ( is_numeric( $id_or_args ) ) {
73
+			$this->id   = (int) $id_or_args;
74
+			$this->post = get_post( $this->id );
75
+			$this->new  = false;
76
+		}
77
+
78
+		if ( is_array( $id_or_args ) ) {
79
+			$this->args = $id_or_args;
80
+
81
+			if ( isset( $this->args['ID'] ) ) {
82
+				$this->post = get_post( $this->args['ID'] );
83
+
84
+				if ( $this->post ) {
85
+					$this->id  = $this->post->ID;
86
+					$this->new = false;
87
+				} else {
88
+					unset( $this->args['ID'] );
89
+				}
90
+			}
91
+		}
92
+	}
93
+
94
+	public function id() {
95
+		return $this->id;
96
+	}
97
+
98
+	/**
99
+	 * Returns the post type
100
+	 */
101
+	public function type() {
102
+		return $this->post->post_type;
103
+	}
104
+
105
+	/**
106
+	 * Returns the post type
107
+	 */
108
+	public function status() {
109
+		return $this->post->post_status;
110
+	}
111
+
112
+	/**
113
+	 * Returns the post name
114
+	 */
115
+	public function name() {
116
+		return $this->post->post_name;
117
+	}
118
+
119
+	/**
120
+	 * Returns true if the post has a password
121
+	 * @return bool
122
+	 */
123
+	public function has_password() {
124
+		return ! empty( $this->post->post_password );
125
+	}
126
+
127
+	/**
128
+	 * Combines the 2 content parts for GitHub
129
+	 */
130
+	public function github_content() {
131
+		$use_blob = wogh_is_dont_export_content() && $this->blob;
132
+		$content = $use_blob ?
133
+			$this->blob->post_content() :
134
+			$this->post_content();
135
+
136
+		return $this->front_matter() . $content;
137
+		// $content = $this->front_matter() . $content;
138
+		// $ending  = apply_filters( 'wogh_line_endings', "\n" );
139
+
140
+		// return preg_replace( '~(*BSR_ANYCRLF)\R~', $ending, $content );
141
+	}
142
+
143
+	/**
144
+	 * The post's YAML frontmatter
145
+	 *
146
+	 * Returns String the YAML frontmatter, ready to be written to the file
147
+	 */
148
+	public function front_matter() {
149
+		return "---\n" . spyc_dump( $this->meta() ) . "---\n";
150
+	}
151
+
152
+	/**
153
+	 * Returns the post_content
154
+	 *
155
+	 * Markdownify's the content if applicable
156
+	 */
157
+	public function post_content() {
158
+		$content = $this->post->post_content;
159
+
160
+		if ( function_exists( 'wpmarkdown_html_to_markdown' ) ) {
161
+			$content = wpmarkdown_html_to_markdown( $content );
162
+		} else if ( class_exists( 'WPCom_Markdown' ) ) {
163
+			if ( WPCom_Markdown::get_instance()->is_markdown( $this->post->ID ) ) {
164
+				$content = $this->post->post_content_filtered;
165
+			}
166
+		}
167
+
168
+		return apply_filters( 'wogh_content_export', $content, $this );
169
+	}
170
+
171
+	public function old_github_path() {
172
+		return $this->old_github_path;
173
+	}
174
+
175
+	public function set_old_github_path( $path ) {
176
+		$this->old_github_path = $path;
177
+		update_post_meta( $this->id, '_wogh_github_path', $path );
178
+	}
179
+
180
+
181
+	/**
182
+	 * Retrieves or calculates the proper GitHub path for a given post
183
+	 *
184
+	 * Returns (string) the path relative to repo root
185
+	 */
186
+	public function github_path() {
187
+		$path = $this->github_directory() . $this->github_filename();
188
+
189
+		return $path;
190
+	}
191
+
192
+	/**
193
+	 * Get GitHub directory based on post
194
+	 *
195
+	 * @return string
196
+	 */
197
+	public function github_directory() {
198
+		if ( 'publish' !== $this->status() ) {
199
+			return apply_filters( 'wogh_directory_unpublished', '_drafts/', $this );
200
+		}
201
+
202
+		$name = '';
203
+
204
+		switch ( $this->type() ) {
205
+			case 'post':
206
+				$name = 'posts';
207
+				break;
208
+			case 'page':
209
+				$name = 'pages';
210
+				break;
211
+			default:
212
+				$obj = get_post_type_object( $this->type() );
213
+
214
+				if ( $obj ) {
215
+					$name = strtolower( $obj->labels->name );
216
+				}
217
+
218
+				if ( ! $name ) {
219
+					$name = '';
220
+				}
221
+		}
222
+
223
+		if ( $name ) {
224
+			$name = '_' . $name . '/';
225
+		}
226
+
227
+		return apply_filters( 'wogh_directory_published', $name, $this );
228
+	}
229
+
230
+	/**
231
+	 * Build GitHub filename based on post
232
+	 */
233
+	public function github_filename() {
234
+		if ( 'post' === $this->type() ) {
235
+			$filename = get_the_time( 'Y-m-d-', $this->id ) . $this->get_name() . '.md';
236
+		} else {
237
+			$filename = $this->get_name() . '.md';
238
+		}
239
+
240
+		return apply_filters( 'wogh_filename', $filename, $this );
241
+	}
242
+
243
+	/**
244
+	 * Returns a post slug we can use in the GitHub filename
245
+	 *
246
+	 * @return string
247
+	 */
248
+	protected function get_name() {
249
+		if ( '' !== $this->name() ) {
250
+			return $this->name();
251
+		}
252
+
253
+		return sanitize_title( get_the_title( $this->post ) );
254
+	}
255
+
256
+	/**
257
+	 * is put on github
258
+	 * @return boolean
259
+	 */
260
+	public function is_on_github() {
261
+		$sha = get_post_meta( $this->id, '_wogh_sha', true );
262
+		$github_path = get_post_meta( $this->id, '_wogh_github_path', true );
263
+		if ( $sha && $github_path ) {
264
+			return true;
265
+		}
266
+		return false;
267
+	}
268
+
269
+	/**
270
+	 * Returns the URL for the post on GitHub.
271
+	 *
272
+	 * @return string
273
+	 */
274
+	public function github_view_url() {
275
+		$github_path = get_post_meta( $this->id, '_wogh_github_path', true );
276
+		$repository = $this->api->fetch()->repository();
277
+		$branch = $this->api->fetch()->branch();
278
+
279
+		return "https://github.com/$repository/blob/$branch/$github_path";
280
+	}
281
+
282
+	/**
283
+	 * Returns the URL for the post on GitHub.
284
+	 *
285
+	 * @return string
286
+	 */
287
+	public function github_edit_url() {
288
+		$github_path = get_post_meta( $this->id, '_wogh_github_path', true );
289
+		$repository = $this->api->fetch()->repository();
290
+		$branch = $this->api->fetch()->branch();
291
+
292
+		return "https://github.com/$repository/edit/$branch/$github_path";
293
+	}
294
+
295
+	/**
296
+	 * Retrieve post type directory from blob path.
297
+	 *
298
+	 * @param string $path Path string.
299
+	 *
300
+	 * @return string
301
+	 */
302
+	public function get_directory_from_path( $path ) {
303
+		$directory = explode( '/', $path );
304
+		$directory = count( $directory ) > 0 ? $directory[0] : '';
305
+
306
+		return $directory;
307
+	}
308
+
309
+	/**
310
+	 * Determines the last author to modify the post
311
+	 *
312
+	 * Returns Array an array containing the author name and email
313
+	 */
314
+	public function last_modified_author() {
315
+		if ( $last_id = get_post_meta( $this->id, '_edit_last', true ) ) {
316
+			$user = get_userdata( $last_id );
317
+
318
+			if ( $user ) {
319
+				return array( 'name' => $user->display_name, 'email' => $user->user_email );
320
+			}
321
+		}
322
+
323
+		return array();
324
+	}
325
+
326
+	/**
327
+	 * The post's sha
328
+	 * Cached as post meta, or will make a live call if need be
329
+	 *
330
+	 * Returns String the sha1 hash
331
+	 */
332
+	public function sha() {
333
+		$sha = get_post_meta( $this->id, '_wogh_sha', true );
334
+
335
+		// If we've done a full export and we have no sha
336
+		// then we should try a live check to see if it exists.
337
+		// if ( ! $sha && 'yes' === get_option( '_wogh_fully_exported' ) ) {
338
+
339
+		//  // @todo could we eliminate this by calling down the full tree and searching it
340
+		//  $data = $this->api->fetch()->remote_contents( $this );
341
+
342
+		//  if ( ! is_wp_error( $data ) ) {
343
+		//      update_post_meta( $this->id, '_wogh_sha', $data->sha );
344
+		//      $sha = $data->sha;
345
+		//  }
346
+		// }
347
+
348
+		// if the sha still doesn't exist, then it's empty
349
+		if ( ! $sha || is_wp_error( $sha ) ) {
350
+			$sha = '';
351
+		}
352
+
353
+		return $sha;
354
+	}
355
+
356
+	/**
357
+	 * Save the sha to post
358
+	 *
359
+	 * @param string $sha
360
+	 */
361
+	public function set_sha( $sha ) {
362
+		update_post_meta( $this->id, '_wogh_sha', $sha );
363
+	}
364
+
365
+	/**
366
+	 * The post's metadata
367
+	 *
368
+	 * Returns Array the post's metadata
369
+	 */
370
+	public function meta() {
371
+		$meta = array(
372
+			'ID'           => $this->id,
373
+			'post_title'   => get_the_title( $this->post ),
374
+			'post_name'    => $this->post->post_name,
375
+			'author'       => ( $author = get_userdata( $this->post->post_author ) ) ? $author->display_name : '',
376
+			'post_date'    => $this->post->post_date,
377
+			'post_excerpt' => $this->post->post_excerpt,
378
+			'layout'       => get_post_type( $this->post ),
379
+			'link'         => get_permalink( $this->post ),
380
+			'published'    => 'publish' === $this->status() ? true : false,
381
+			'tags'         => wp_get_post_tags( $this->id, array( 'fields' => 'names' ) ),
382
+			'categories'   => wp_get_post_categories( $this->id, array( 'fields' => 'names' ) )
383
+		);
384
+		if ( empty($this->post->post_name) ) {
385
+			unset($meta['post_name']);
386
+		}
387
+		if ( empty($this->post->post_excerpt) ) {
388
+			unset($meta['post_excerpt']);
389
+		}
390
+		if ( 'yes' == get_option('wogh_ignore_author') ) {
391
+			unset($meta['author']);
392
+		}
393
+
394
+		//convert traditional post_meta values, hide hidden values, skip already populated values
395
+		// foreach ( get_post_custom( $this->id ) as $key => $value ) {
396
+
397
+		//  if ( '_' === substr( $key, 0, 1 ) || isset( $meta[ $key ] ) ) {
398
+		//      continue;
399
+		//  }
400
+
401
+		//  $meta[ $key ] = $value;
402
+
403
+		// }
404
+
405
+		return apply_filters( 'wogh_post_meta', $meta, $this );
406
+	}
407
+
408
+	/**
409
+	 * Returns whether the Post has been saved in the DB yet.
410
+	 *
411
+	 * @return bool
412
+	 */
413
+	public function is_new() {
414
+		return $this->new;
415
+	}
416
+
417
+	/**
418
+	 * Sets the Post's meta.
419
+	 *
420
+	 * @param array $meta
421
+	 */
422
+	public function set_meta( $meta ) {
423
+		$this->meta = $meta;
424
+	}
425
+
426
+	/**
427
+	 * Returns the Post's arguments.
428
+	 *
429
+	 * @return array
430
+	 */
431
+	public function get_args() {
432
+		return $this->args;
433
+	}
434
+
435
+	/**
436
+	 * Returns the Post's meta.
437
+	 *
438
+	 * @return array
439
+	 */
440
+	public function get_meta() {
441
+		return $this->meta;
442
+	}
443
+
444
+	/**
445
+	 * Get the blob
446
+	 * @return Writing_On_GitHub_Blob
447
+	 */
448
+	public function get_blob() {
449
+		return $this->blob;
450
+	}
451
+
452
+	/**
453
+	 * Set the blob
454
+	 * @param Writing_On_GitHub_Blob $blob
455
+	 */
456
+	public function set_blob( Writing_On_GitHub_Blob $blob ) {
457
+		$this->blob = $blob;
458
+	}
459
+
460
+	/**
461
+	 * Sets the Post's WP_Post object.
462
+	 *
463
+	 * @param WP_Post $post
464
+	 *
465
+	 * @return $this
466
+	 */
467
+	public function set_post( WP_Post $post ) {
468
+		$this->post = $post;
469
+		$this->id   = $post->ID;
470
+
471
+		return $this;
472
+	}
473
+
474
+	/**
475
+	 * Transforms the Post into a Blob.
476
+	 *
477
+	 * @return Writing_On_GitHub_Blob
478
+	 */
479
+	public function to_blob() {
480
+		$data = new stdClass;
481
+
482
+		$data->path    = $this->github_path();
483
+		$data->content = $this->github_content();
484
+		$data->sha     = $this->sha();
485
+
486
+		return new Writing_On_GitHub_Blob( $data );
487
+	}
488 488
 }
Please login to merge, or discard this patch.
Spacing   +62 added lines, -63 removed lines patch added patch discarded remove patch
@@ -66,26 +66,26 @@  discard block
 block discarded – undo
66 66
      *
67 67
      * @todo remove database operations from this method
68 68
      */
69
-    public function __construct( $id_or_args, Writing_On_GitHub_Api $api ) {
69
+    public function __construct($id_or_args, Writing_On_GitHub_Api $api) {
70 70
         $this->api = $api;
71 71
 
72
-        if ( is_numeric( $id_or_args ) ) {
72
+        if (is_numeric($id_or_args)) {
73 73
             $this->id   = (int) $id_or_args;
74
-            $this->post = get_post( $this->id );
74
+            $this->post = get_post($this->id);
75 75
             $this->new  = false;
76 76
         }
77 77
 
78
-        if ( is_array( $id_or_args ) ) {
78
+        if (is_array($id_or_args)) {
79 79
             $this->args = $id_or_args;
80 80
 
81
-            if ( isset( $this->args['ID'] ) ) {
82
-                $this->post = get_post( $this->args['ID'] );
81
+            if (isset($this->args['ID'])) {
82
+                $this->post = get_post($this->args['ID']);
83 83
 
84
-                if ( $this->post ) {
84
+                if ($this->post) {
85 85
                     $this->id  = $this->post->ID;
86 86
                     $this->new = false;
87 87
                 } else {
88
-                    unset( $this->args['ID'] );
88
+                    unset($this->args['ID']);
89 89
                 }
90 90
             }
91 91
         }
@@ -121,7 +121,7 @@  discard block
 block discarded – undo
121 121
      * @return bool
122 122
      */
123 123
     public function has_password() {
124
-        return ! empty( $this->post->post_password );
124
+        return ! empty($this->post->post_password);
125 125
     }
126 126
 
127 127
     /**
@@ -130,8 +130,7 @@  discard block
 block discarded – undo
130 130
     public function github_content() {
131 131
         $use_blob = wogh_is_dont_export_content() && $this->blob;
132 132
         $content = $use_blob ?
133
-            $this->blob->post_content() :
134
-            $this->post_content();
133
+            $this->blob->post_content() : $this->post_content();
135 134
 
136 135
         return $this->front_matter() . $content;
137 136
         // $content = $this->front_matter() . $content;
@@ -146,7 +145,7 @@  discard block
 block discarded – undo
146 145
      * Returns String the YAML frontmatter, ready to be written to the file
147 146
      */
148 147
     public function front_matter() {
149
-        return "---\n" . spyc_dump( $this->meta() ) . "---\n";
148
+        return "---\n" . spyc_dump($this->meta()) . "---\n";
150 149
     }
151 150
 
152 151
     /**
@@ -157,24 +156,24 @@  discard block
 block discarded – undo
157 156
     public function post_content() {
158 157
         $content = $this->post->post_content;
159 158
 
160
-        if ( function_exists( 'wpmarkdown_html_to_markdown' ) ) {
161
-            $content = wpmarkdown_html_to_markdown( $content );
162
-        } else if ( class_exists( 'WPCom_Markdown' ) ) {
163
-            if ( WPCom_Markdown::get_instance()->is_markdown( $this->post->ID ) ) {
159
+        if (function_exists('wpmarkdown_html_to_markdown')) {
160
+            $content = wpmarkdown_html_to_markdown($content);
161
+        } else if (class_exists('WPCom_Markdown')) {
162
+            if (WPCom_Markdown::get_instance()->is_markdown($this->post->ID)) {
164 163
                 $content = $this->post->post_content_filtered;
165 164
             }
166 165
         }
167 166
 
168
-        return apply_filters( 'wogh_content_export', $content, $this );
167
+        return apply_filters('wogh_content_export', $content, $this);
169 168
     }
170 169
 
171 170
     public function old_github_path() {
172 171
         return $this->old_github_path;
173 172
     }
174 173
 
175
-    public function set_old_github_path( $path ) {
174
+    public function set_old_github_path($path) {
176 175
         $this->old_github_path = $path;
177
-        update_post_meta( $this->id, '_wogh_github_path', $path );
176
+        update_post_meta($this->id, '_wogh_github_path', $path);
178 177
     }
179 178
 
180 179
 
@@ -195,13 +194,13 @@  discard block
 block discarded – undo
195 194
      * @return string
196 195
      */
197 196
     public function github_directory() {
198
-        if ( 'publish' !== $this->status() ) {
199
-            return apply_filters( 'wogh_directory_unpublished', '_drafts/', $this );
197
+        if ('publish' !== $this->status()) {
198
+            return apply_filters('wogh_directory_unpublished', '_drafts/', $this);
200 199
         }
201 200
 
202 201
         $name = '';
203 202
 
204
-        switch ( $this->type() ) {
203
+        switch ($this->type()) {
205 204
             case 'post':
206 205
                 $name = 'posts';
207 206
                 break;
@@ -209,35 +208,35 @@  discard block
 block discarded – undo
209 208
                 $name = 'pages';
210 209
                 break;
211 210
             default:
212
-                $obj = get_post_type_object( $this->type() );
211
+                $obj = get_post_type_object($this->type());
213 212
 
214
-                if ( $obj ) {
215
-                    $name = strtolower( $obj->labels->name );
213
+                if ($obj) {
214
+                    $name = strtolower($obj->labels->name);
216 215
                 }
217 216
 
218
-                if ( ! $name ) {
217
+                if ( ! $name) {
219 218
                     $name = '';
220 219
                 }
221 220
         }
222 221
 
223
-        if ( $name ) {
222
+        if ($name) {
224 223
             $name = '_' . $name . '/';
225 224
         }
226 225
 
227
-        return apply_filters( 'wogh_directory_published', $name, $this );
226
+        return apply_filters('wogh_directory_published', $name, $this);
228 227
     }
229 228
 
230 229
     /**
231 230
      * Build GitHub filename based on post
232 231
      */
233 232
     public function github_filename() {
234
-        if ( 'post' === $this->type() ) {
235
-            $filename = get_the_time( 'Y-m-d-', $this->id ) . $this->get_name() . '.md';
233
+        if ('post' === $this->type()) {
234
+            $filename = get_the_time('Y-m-d-', $this->id) . $this->get_name() . '.md';
236 235
         } else {
237 236
             $filename = $this->get_name() . '.md';
238 237
         }
239 238
 
240
-        return apply_filters( 'wogh_filename', $filename, $this );
239
+        return apply_filters('wogh_filename', $filename, $this);
241 240
     }
242 241
 
243 242
     /**
@@ -246,11 +245,11 @@  discard block
 block discarded – undo
246 245
      * @return string
247 246
      */
248 247
     protected function get_name() {
249
-        if ( '' !== $this->name() ) {
248
+        if ('' !== $this->name()) {
250 249
             return $this->name();
251 250
         }
252 251
 
253
-        return sanitize_title( get_the_title( $this->post ) );
252
+        return sanitize_title(get_the_title($this->post));
254 253
     }
255 254
 
256 255
     /**
@@ -258,9 +257,9 @@  discard block
 block discarded – undo
258 257
      * @return boolean
259 258
      */
260 259
     public function is_on_github() {
261
-        $sha = get_post_meta( $this->id, '_wogh_sha', true );
262
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
263
-        if ( $sha && $github_path ) {
260
+        $sha = get_post_meta($this->id, '_wogh_sha', true);
261
+        $github_path = get_post_meta($this->id, '_wogh_github_path', true);
262
+        if ($sha && $github_path) {
264 263
             return true;
265 264
         }
266 265
         return false;
@@ -272,7 +271,7 @@  discard block
 block discarded – undo
272 271
      * @return string
273 272
      */
274 273
     public function github_view_url() {
275
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
274
+        $github_path = get_post_meta($this->id, '_wogh_github_path', true);
276 275
         $repository = $this->api->fetch()->repository();
277 276
         $branch = $this->api->fetch()->branch();
278 277
 
@@ -285,7 +284,7 @@  discard block
 block discarded – undo
285 284
      * @return string
286 285
      */
287 286
     public function github_edit_url() {
288
-        $github_path = get_post_meta( $this->id, '_wogh_github_path', true );
287
+        $github_path = get_post_meta($this->id, '_wogh_github_path', true);
289 288
         $repository = $this->api->fetch()->repository();
290 289
         $branch = $this->api->fetch()->branch();
291 290
 
@@ -299,9 +298,9 @@  discard block
 block discarded – undo
299 298
      *
300 299
      * @return string
301 300
      */
302
-    public function get_directory_from_path( $path ) {
303
-        $directory = explode( '/', $path );
304
-        $directory = count( $directory ) > 0 ? $directory[0] : '';
301
+    public function get_directory_from_path($path) {
302
+        $directory = explode('/', $path);
303
+        $directory = count($directory) > 0 ? $directory[0] : '';
305 304
 
306 305
         return $directory;
307 306
     }
@@ -312,11 +311,11 @@  discard block
 block discarded – undo
312 311
      * Returns Array an array containing the author name and email
313 312
      */
314 313
     public function last_modified_author() {
315
-        if ( $last_id = get_post_meta( $this->id, '_edit_last', true ) ) {
316
-            $user = get_userdata( $last_id );
314
+        if ($last_id = get_post_meta($this->id, '_edit_last', true)) {
315
+            $user = get_userdata($last_id);
317 316
 
318
-            if ( $user ) {
319
-                return array( 'name' => $user->display_name, 'email' => $user->user_email );
317
+            if ($user) {
318
+                return array('name' => $user->display_name, 'email' => $user->user_email);
320 319
             }
321 320
         }
322 321
 
@@ -330,7 +329,7 @@  discard block
 block discarded – undo
330 329
      * Returns String the sha1 hash
331 330
      */
332 331
     public function sha() {
333
-        $sha = get_post_meta( $this->id, '_wogh_sha', true );
332
+        $sha = get_post_meta($this->id, '_wogh_sha', true);
334 333
 
335 334
         // If we've done a full export and we have no sha
336 335
         // then we should try a live check to see if it exists.
@@ -346,7 +345,7 @@  discard block
 block discarded – undo
346 345
         // }
347 346
 
348 347
         // if the sha still doesn't exist, then it's empty
349
-        if ( ! $sha || is_wp_error( $sha ) ) {
348
+        if ( ! $sha || is_wp_error($sha)) {
350 349
             $sha = '';
351 350
         }
352 351
 
@@ -358,8 +357,8 @@  discard block
 block discarded – undo
358 357
      *
359 358
      * @param string $sha
360 359
      */
361
-    public function set_sha( $sha ) {
362
-        update_post_meta( $this->id, '_wogh_sha', $sha );
360
+    public function set_sha($sha) {
361
+        update_post_meta($this->id, '_wogh_sha', $sha);
363 362
     }
364 363
 
365 364
     /**
@@ -370,24 +369,24 @@  discard block
 block discarded – undo
370 369
     public function meta() {
371 370
         $meta = array(
372 371
             'ID'           => $this->id,
373
-            'post_title'   => get_the_title( $this->post ),
372
+            'post_title'   => get_the_title($this->post),
374 373
             'post_name'    => $this->post->post_name,
375
-            'author'       => ( $author = get_userdata( $this->post->post_author ) ) ? $author->display_name : '',
374
+            'author'       => ($author = get_userdata($this->post->post_author)) ? $author->display_name : '',
376 375
             'post_date'    => $this->post->post_date,
377 376
             'post_excerpt' => $this->post->post_excerpt,
378
-            'layout'       => get_post_type( $this->post ),
379
-            'link'         => get_permalink( $this->post ),
377
+            'layout'       => get_post_type($this->post),
378
+            'link'         => get_permalink($this->post),
380 379
             'published'    => 'publish' === $this->status() ? true : false,
381
-            'tags'         => wp_get_post_tags( $this->id, array( 'fields' => 'names' ) ),
382
-            'categories'   => wp_get_post_categories( $this->id, array( 'fields' => 'names' ) )
380
+            'tags'         => wp_get_post_tags($this->id, array('fields' => 'names')),
381
+            'categories'   => wp_get_post_categories($this->id, array('fields' => 'names'))
383 382
         );
384
-        if ( empty($this->post->post_name) ) {
383
+        if (empty($this->post->post_name)) {
385 384
             unset($meta['post_name']);
386 385
         }
387
-        if ( empty($this->post->post_excerpt) ) {
386
+        if (empty($this->post->post_excerpt)) {
388 387
             unset($meta['post_excerpt']);
389 388
         }
390
-        if ( 'yes' == get_option('wogh_ignore_author') ) {
389
+        if ('yes' == get_option('wogh_ignore_author')) {
391 390
             unset($meta['author']);
392 391
         }
393 392
 
@@ -402,7 +401,7 @@  discard block
 block discarded – undo
402 401
 
403 402
         // }
404 403
 
405
-        return apply_filters( 'wogh_post_meta', $meta, $this );
404
+        return apply_filters('wogh_post_meta', $meta, $this);
406 405
     }
407 406
 
408 407
     /**
@@ -419,7 +418,7 @@  discard block
 block discarded – undo
419 418
      *
420 419
      * @param array $meta
421 420
      */
422
-    public function set_meta( $meta ) {
421
+    public function set_meta($meta) {
423 422
         $this->meta = $meta;
424 423
     }
425 424
 
@@ -453,7 +452,7 @@  discard block
 block discarded – undo
453 452
      * Set the blob
454 453
      * @param Writing_On_GitHub_Blob $blob
455 454
      */
456
-    public function set_blob( Writing_On_GitHub_Blob $blob ) {
455
+    public function set_blob(Writing_On_GitHub_Blob $blob) {
457 456
         $this->blob = $blob;
458 457
     }
459 458
 
@@ -464,7 +463,7 @@  discard block
 block discarded – undo
464 463
      *
465 464
      * @return $this
466 465
      */
467
-    public function set_post( WP_Post $post ) {
466
+    public function set_post(WP_Post $post) {
468 467
         $this->post = $post;
469 468
         $this->id   = $post->ID;
470 469
 
@@ -483,6 +482,6 @@  discard block
 block discarded – undo
483 482
         $data->content = $this->github_content();
484 483
         $data->sha     = $this->sha();
485 484
 
486
-        return new Writing_On_GitHub_Blob( $data );
485
+        return new Writing_On_GitHub_Blob($data);
487 486
     }
488 487
 }
Please login to merge, or discard this patch.
lib/blob.php 2 patches
Indentation   +239 added lines, -239 removed lines patch added patch discarded remove patch
@@ -9,243 +9,243 @@
 block discarded – undo
9 9
  */
10 10
 class Writing_On_GitHub_Blob {
11 11
 
12
-    /**
13
-     * Complete blob content.
14
-     *
15
-     * @var string
16
-     */
17
-    protected $content;
18
-
19
-    /**
20
-     * Blob sha.
21
-     *
22
-     * @var string
23
-     */
24
-    protected $sha;
25
-
26
-    /**
27
-     * Blob path.
28
-     *
29
-     * @var string
30
-     */
31
-    protected $path;
32
-
33
-    /**
34
-     * Post id.
35
-     *
36
-     * @var int
37
-     */
38
-    protected $id;
39
-
40
-    /**
41
-     * Whether the blob has frontmatter.
42
-     *
43
-     * @var boolean
44
-     */
45
-    protected $frontmatter = false;
46
-
47
-    /**
48
-     * The front matter of github post
49
-     * @var string
50
-     */
51
-    protected $front_matter = '';
52
-
53
-    /**
54
-     * Content without front matter
55
-     * @var string
56
-     */
57
-    protected $post_content;
58
-
59
-    /**
60
-     * Instantiates a new Blob object.
61
-     *
62
-     * @param stdClass $data Raw blob data.
63
-     */
64
-    public function __construct( stdClass $data ) {
65
-        $this->interpret_data( $data );
66
-    }
67
-
68
-    public function id() {
69
-        return $this->id;
70
-    }
71
-
72
-    public function set_id($id) {
73
-        $this->id = $id;
74
-    }
75
-
76
-    /**
77
-     * Returns the raw blob content.
78
-     *
79
-     * @return string
80
-     */
81
-    public function content() {
82
-        return $this->content;
83
-    }
84
-
85
-    /**
86
-     * Set's the blob's content.
87
-     *
88
-     * @param string $content Raw blob content.
89
-     * @param bool   $base64 Whether the content is base64 encoded.
90
-     *
91
-     * @return $this
92
-     */
93
-    public function set_content( $content, $base64 = false ) {
94
-        if ( $base64 ) {
95
-            $content = base64_decode( $content );
96
-        }
97
-
98
-        $this->frontmatter = '---' === substr( $this->content = $content, 0, 3 );
99
-
100
-        return $this;
101
-    }
102
-    /**
103
-     * Returns the blob sha.
104
-     *
105
-     * @return string
106
-     */
107
-    public function sha() {
108
-        return $this->sha;
109
-    }
110
-
111
-    /**
112
-     * Return's the blob path.
113
-     *
114
-     * @return string
115
-     */
116
-    public function path() {
117
-        return $this->path;
118
-    }
119
-
120
-    /**
121
-     * Whether the blob has frontmatter.
122
-     *
123
-     * @return bool
124
-     */
125
-    public function has_frontmatter() {
126
-        return $this->frontmatter;
127
-    }
128
-
129
-    /**
130
-     * The front matter of github post
131
-     * @return string
132
-     */
133
-    public function front_matter() {
134
-        return $this->front_matter;
135
-    }
136
-
137
-    /**
138
-     * Content without front matter
139
-     * @return string
140
-     */
141
-    public function post_content() {
142
-        if ( ! $this->post_content ) {
143
-            $this->content_import();
144
-        }
145
-        return $this->post_content;
146
-    }
147
-
148
-    /**
149
-     * Returns the formatted/filtered blob content used for import.
150
-     *
151
-     * @return string
152
-     */
153
-    public function content_import() {
154
-        $this->post_content = $content = $this->content();
155
-
156
-        if ( $this->has_frontmatter() ) {
157
-            // Break out content.
158
-            preg_match( '/(^---(.*?)---$(\r\n|\n|\r)?)?(.*)/ms', $content, $matches );
159
-            $this->front_matter = $matches[1];
160
-            $this->post_content = $content = array_pop( $matches );
161
-        }
162
-
163
-        if ( function_exists( 'wpmarkdown_markdown_to_html' ) ) {
164
-            $content = wpmarkdown_markdown_to_html( $content );
165
-        }
166
-
167
-        /**
168
-         * Filters the content for import.
169
-         */
170
-        return apply_filters( 'wogh_content_import', trim( $content ) );
171
-    }
172
-
173
-    /**
174
-     * Returns the blob meta.
175
-     *
176
-     * @return array
177
-     */
178
-    public function meta() {
179
-        $meta = array();
180
-
181
-        if ( $this->has_frontmatter() ) {
182
-            // Break out meta, if present.
183
-            preg_match( '/(^---(.*?)---$)?(.*)/ms', $this->content(), $matches );
184
-            array_pop( $matches );
185
-
186
-            $meta = spyc_load( $matches[2] );
187
-            if ( 'yes' == get_option('wogh_ignore_author') ) {
188
-                unset($meta['author']);
189
-            }
190
-            // if ( isset( $meta['link'] ) ) {
191
-            //  $meta['link'] = str_replace( home_url(), '', $meta['link'] );
192
-            // }
193
-        }
194
-
195
-        return $meta;
196
-    }
197
-
198
-    /**
199
-     * Formats the blob into an API call body.
200
-     *
201
-     * @return stdClass
202
-     */
203
-    // public function to_body() {
204
-    //  $data = new stdClass;
205
-
206
-    //  $data->mode = '100644';
207
-    //  $data->type = 'blob';
208
-
209
-    //  $data->path = $this->path();
210
-
211
-    //  if ( $this->sha() ) {
212
-    //      $data->sha = $this->sha();
213
-    //  } else {
214
-    //      $data->content = $this->content();
215
-    //  }
216
-
217
-    //  return $data;
218
-    // }
219
-
220
-
221
-    /**
222
-     * Formats the blob into an API call body.
223
-     *
224
-     * @return stdClass
225
-     */
226
-    public function to_body() {
227
-        $data = new stdClass;
228
-
229
-        // $data->mode = '100644';
230
-        // $data->type = 'blob';
231
-
232
-        $data->path = $this->path();
233
-        $data->content = base64_encode( $this->content() );
234
-        $data->sha = $this->sha;
235
-
236
-        return $data;
237
-    }
238
-
239
-    /**
240
-     * Interprets the blob's data into properties.
241
-     */
242
-    protected function interpret_data( $data ) {
243
-        $this->sha  = isset( $data->sha  ) ? $data->sha  : '';
244
-        $this->path = isset( $data->path ) ? $data->path : '';
245
-
246
-        $this->set_content(
247
-            isset( $data->content ) ? trim( $data->content ) : '',
248
-            isset( $data->encoding ) && 'base64' === $data->encoding ? true : false
249
-        );
250
-    }
12
+	/**
13
+	 * Complete blob content.
14
+	 *
15
+	 * @var string
16
+	 */
17
+	protected $content;
18
+
19
+	/**
20
+	 * Blob sha.
21
+	 *
22
+	 * @var string
23
+	 */
24
+	protected $sha;
25
+
26
+	/**
27
+	 * Blob path.
28
+	 *
29
+	 * @var string
30
+	 */
31
+	protected $path;
32
+
33
+	/**
34
+	 * Post id.
35
+	 *
36
+	 * @var int
37
+	 */
38
+	protected $id;
39
+
40
+	/**
41
+	 * Whether the blob has frontmatter.
42
+	 *
43
+	 * @var boolean
44
+	 */
45
+	protected $frontmatter = false;
46
+
47
+	/**
48
+	 * The front matter of github post
49
+	 * @var string
50
+	 */
51
+	protected $front_matter = '';
52
+
53
+	/**
54
+	 * Content without front matter
55
+	 * @var string
56
+	 */
57
+	protected $post_content;
58
+
59
+	/**
60
+	 * Instantiates a new Blob object.
61
+	 *
62
+	 * @param stdClass $data Raw blob data.
63
+	 */
64
+	public function __construct( stdClass $data ) {
65
+		$this->interpret_data( $data );
66
+	}
67
+
68
+	public function id() {
69
+		return $this->id;
70
+	}
71
+
72
+	public function set_id($id) {
73
+		$this->id = $id;
74
+	}
75
+
76
+	/**
77
+	 * Returns the raw blob content.
78
+	 *
79
+	 * @return string
80
+	 */
81
+	public function content() {
82
+		return $this->content;
83
+	}
84
+
85
+	/**
86
+	 * Set's the blob's content.
87
+	 *
88
+	 * @param string $content Raw blob content.
89
+	 * @param bool   $base64 Whether the content is base64 encoded.
90
+	 *
91
+	 * @return $this
92
+	 */
93
+	public function set_content( $content, $base64 = false ) {
94
+		if ( $base64 ) {
95
+			$content = base64_decode( $content );
96
+		}
97
+
98
+		$this->frontmatter = '---' === substr( $this->content = $content, 0, 3 );
99
+
100
+		return $this;
101
+	}
102
+	/**
103
+	 * Returns the blob sha.
104
+	 *
105
+	 * @return string
106
+	 */
107
+	public function sha() {
108
+		return $this->sha;
109
+	}
110
+
111
+	/**
112
+	 * Return's the blob path.
113
+	 *
114
+	 * @return string
115
+	 */
116
+	public function path() {
117
+		return $this->path;
118
+	}
119
+
120
+	/**
121
+	 * Whether the blob has frontmatter.
122
+	 *
123
+	 * @return bool
124
+	 */
125
+	public function has_frontmatter() {
126
+		return $this->frontmatter;
127
+	}
128
+
129
+	/**
130
+	 * The front matter of github post
131
+	 * @return string
132
+	 */
133
+	public function front_matter() {
134
+		return $this->front_matter;
135
+	}
136
+
137
+	/**
138
+	 * Content without front matter
139
+	 * @return string
140
+	 */
141
+	public function post_content() {
142
+		if ( ! $this->post_content ) {
143
+			$this->content_import();
144
+		}
145
+		return $this->post_content;
146
+	}
147
+
148
+	/**
149
+	 * Returns the formatted/filtered blob content used for import.
150
+	 *
151
+	 * @return string
152
+	 */
153
+	public function content_import() {
154
+		$this->post_content = $content = $this->content();
155
+
156
+		if ( $this->has_frontmatter() ) {
157
+			// Break out content.
158
+			preg_match( '/(^---(.*?)---$(\r\n|\n|\r)?)?(.*)/ms', $content, $matches );
159
+			$this->front_matter = $matches[1];
160
+			$this->post_content = $content = array_pop( $matches );
161
+		}
162
+
163
+		if ( function_exists( 'wpmarkdown_markdown_to_html' ) ) {
164
+			$content = wpmarkdown_markdown_to_html( $content );
165
+		}
166
+
167
+		/**
168
+		 * Filters the content for import.
169
+		 */
170
+		return apply_filters( 'wogh_content_import', trim( $content ) );
171
+	}
172
+
173
+	/**
174
+	 * Returns the blob meta.
175
+	 *
176
+	 * @return array
177
+	 */
178
+	public function meta() {
179
+		$meta = array();
180
+
181
+		if ( $this->has_frontmatter() ) {
182
+			// Break out meta, if present.
183
+			preg_match( '/(^---(.*?)---$)?(.*)/ms', $this->content(), $matches );
184
+			array_pop( $matches );
185
+
186
+			$meta = spyc_load( $matches[2] );
187
+			if ( 'yes' == get_option('wogh_ignore_author') ) {
188
+				unset($meta['author']);
189
+			}
190
+			// if ( isset( $meta['link'] ) ) {
191
+			//  $meta['link'] = str_replace( home_url(), '', $meta['link'] );
192
+			// }
193
+		}
194
+
195
+		return $meta;
196
+	}
197
+
198
+	/**
199
+	 * Formats the blob into an API call body.
200
+	 *
201
+	 * @return stdClass
202
+	 */
203
+	// public function to_body() {
204
+	//  $data = new stdClass;
205
+
206
+	//  $data->mode = '100644';
207
+	//  $data->type = 'blob';
208
+
209
+	//  $data->path = $this->path();
210
+
211
+	//  if ( $this->sha() ) {
212
+	//      $data->sha = $this->sha();
213
+	//  } else {
214
+	//      $data->content = $this->content();
215
+	//  }
216
+
217
+	//  return $data;
218
+	// }
219
+
220
+
221
+	/**
222
+	 * Formats the blob into an API call body.
223
+	 *
224
+	 * @return stdClass
225
+	 */
226
+	public function to_body() {
227
+		$data = new stdClass;
228
+
229
+		// $data->mode = '100644';
230
+		// $data->type = 'blob';
231
+
232
+		$data->path = $this->path();
233
+		$data->content = base64_encode( $this->content() );
234
+		$data->sha = $this->sha;
235
+
236
+		return $data;
237
+	}
238
+
239
+	/**
240
+	 * Interprets the blob's data into properties.
241
+	 */
242
+	protected function interpret_data( $data ) {
243
+		$this->sha  = isset( $data->sha  ) ? $data->sha  : '';
244
+		$this->path = isset( $data->path ) ? $data->path : '';
245
+
246
+		$this->set_content(
247
+			isset( $data->content ) ? trim( $data->content ) : '',
248
+			isset( $data->encoding ) && 'base64' === $data->encoding ? true : false
249
+		);
250
+	}
251 251
 }
Please login to merge, or discard this patch.
Spacing   +24 added lines, -24 removed lines patch added patch discarded remove patch
@@ -61,8 +61,8 @@  discard block
 block discarded – undo
61 61
      *
62 62
      * @param stdClass $data Raw blob data.
63 63
      */
64
-    public function __construct( stdClass $data ) {
65
-        $this->interpret_data( $data );
64
+    public function __construct(stdClass $data) {
65
+        $this->interpret_data($data);
66 66
     }
67 67
 
68 68
     public function id() {
@@ -90,12 +90,12 @@  discard block
 block discarded – undo
90 90
      *
91 91
      * @return $this
92 92
      */
93
-    public function set_content( $content, $base64 = false ) {
94
-        if ( $base64 ) {
95
-            $content = base64_decode( $content );
93
+    public function set_content($content, $base64 = false) {
94
+        if ($base64) {
95
+            $content = base64_decode($content);
96 96
         }
97 97
 
98
-        $this->frontmatter = '---' === substr( $this->content = $content, 0, 3 );
98
+        $this->frontmatter = '---' === substr($this->content = $content, 0, 3);
99 99
 
100 100
         return $this;
101 101
     }
@@ -139,7 +139,7 @@  discard block
 block discarded – undo
139 139
      * @return string
140 140
      */
141 141
     public function post_content() {
142
-        if ( ! $this->post_content ) {
142
+        if ( ! $this->post_content) {
143 143
             $this->content_import();
144 144
         }
145 145
         return $this->post_content;
@@ -153,21 +153,21 @@  discard block
 block discarded – undo
153 153
     public function content_import() {
154 154
         $this->post_content = $content = $this->content();
155 155
 
156
-        if ( $this->has_frontmatter() ) {
156
+        if ($this->has_frontmatter()) {
157 157
             // Break out content.
158
-            preg_match( '/(^---(.*?)---$(\r\n|\n|\r)?)?(.*)/ms', $content, $matches );
158
+            preg_match('/(^---(.*?)---$(\r\n|\n|\r)?)?(.*)/ms', $content, $matches);
159 159
             $this->front_matter = $matches[1];
160
-            $this->post_content = $content = array_pop( $matches );
160
+            $this->post_content = $content = array_pop($matches);
161 161
         }
162 162
 
163
-        if ( function_exists( 'wpmarkdown_markdown_to_html' ) ) {
164
-            $content = wpmarkdown_markdown_to_html( $content );
163
+        if (function_exists('wpmarkdown_markdown_to_html')) {
164
+            $content = wpmarkdown_markdown_to_html($content);
165 165
         }
166 166
 
167 167
         /**
168 168
          * Filters the content for import.
169 169
          */
170
-        return apply_filters( 'wogh_content_import', trim( $content ) );
170
+        return apply_filters('wogh_content_import', trim($content));
171 171
     }
172 172
 
173 173
     /**
@@ -178,13 +178,13 @@  discard block
 block discarded – undo
178 178
     public function meta() {
179 179
         $meta = array();
180 180
 
181
-        if ( $this->has_frontmatter() ) {
181
+        if ($this->has_frontmatter()) {
182 182
             // Break out meta, if present.
183
-            preg_match( '/(^---(.*?)---$)?(.*)/ms', $this->content(), $matches );
184
-            array_pop( $matches );
183
+            preg_match('/(^---(.*?)---$)?(.*)/ms', $this->content(), $matches);
184
+            array_pop($matches);
185 185
 
186
-            $meta = spyc_load( $matches[2] );
187
-            if ( 'yes' == get_option('wogh_ignore_author') ) {
186
+            $meta = spyc_load($matches[2]);
187
+            if ('yes' == get_option('wogh_ignore_author')) {
188 188
                 unset($meta['author']);
189 189
             }
190 190
             // if ( isset( $meta['link'] ) ) {
@@ -230,7 +230,7 @@  discard block
 block discarded – undo
230 230
         // $data->type = 'blob';
231 231
 
232 232
         $data->path = $this->path();
233
-        $data->content = base64_encode( $this->content() );
233
+        $data->content = base64_encode($this->content());
234 234
         $data->sha = $this->sha;
235 235
 
236 236
         return $data;
@@ -239,13 +239,13 @@  discard block
 block discarded – undo
239 239
     /**
240 240
      * Interprets the blob's data into properties.
241 241
      */
242
-    protected function interpret_data( $data ) {
243
-        $this->sha  = isset( $data->sha  ) ? $data->sha  : '';
244
-        $this->path = isset( $data->path ) ? $data->path : '';
242
+    protected function interpret_data($data) {
243
+        $this->sha  = isset($data->sha) ? $data->sha : '';
244
+        $this->path = isset($data->path) ? $data->path : '';
245 245
 
246 246
         $this->set_content(
247
-            isset( $data->content ) ? trim( $data->content ) : '',
248
-            isset( $data->encoding ) && 'base64' === $data->encoding ? true : false
247
+            isset($data->content) ? trim($data->content) : '',
248
+            isset($data->encoding) && 'base64' === $data->encoding ? true : false
249 249
         );
250 250
     }
251 251
 }
Please login to merge, or discard this patch.