You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

114 lines
4.3 KiB

8 years ago
<?php
/**
* This is a bare-bones to get you started with developing an access method. The methods provided below are all ones you will want to use (though note that the provided email.php method is an
* example of truly bare-bones for a method that cannot delete or download and has no configuration).
*
* Read the existing methods for help. There is no hard-and-fast need to put all your code in this file; it is just for increasing convenience and maintainability; there are no bonus points for 100% elegance. If you need access to some part of WordPress that you can only reach through the main plugin file (updraftplus.php), then go right ahead and patch that.
*
* Some handy tips:
* - Search-and-replace "template" for the name of your access method
* - You can also add the methods config_print_javascript_onready and credentials_test if you like
* - Name your file accordingly (it is now template.php)
* - Add the method to the array $backup_methods in updraftplus.php when ready
* - Use the constant UPDRAFTPLUS_DIR to reach Updraft's plugin directory
* - Call $updraftplus->log("my log message") to log things, which greatly helps debugging
* - UpdraftPlus is licenced under the GPLv3 or later. In order to combine your backup method with UpdraftPlus, you will need to licence to anyone and everyone that you distribute it to in a compatible way.
*/
8 years ago
if (!defined('UPDRAFTPLUS_DIR')) die('No direct access allowed.');
if (!class_exists('UpdraftPlus_BackupModule')) require_once(UPDRAFTPLUS_DIR.'/methods/backup-module.php');
class UpdraftPlus_BackupModule_template extends UpdraftPlus_BackupModule {
8 years ago
/**
* backup method: takes an array, and shovels them off to the cloud storage
*
* @param Array $backup_array Array of files (basenames) to sent to remote storage
* @return Mixed - (boolean)false to indicate failure; otherwise, something to be passed back when deleting files
*/
8 years ago
public function backup($backup_array) {
global $updraftplus;
// foreach ($backup_array as $file) {
8 years ago
// Do our uploading stuff...
// If successful, then you must do this:
// $updraftplus->uploaded_file($file);
// }
8 years ago
}
/**
* This function lists the files found in the configured storage location
*
* @param String $match a substring to require (tested via strpos() !== false)
*
* @return Array - each file is represented by an array with entries 'name' and (optional) 'size'
*/
8 years ago
public function listfiles($match = 'backup_') {
// This function needs to return an array of arrays. The keys for the sub-arrays are name (a path-less filename, i.e. a basename), (optional)size, and should be a list of matching files from the storage backend. A WP_Error object can also be returned; and the error code should be no_settings if that is relevant.
8 years ago
return array();
}
/**
* delete method: takes an array of file names (base name) or a single string, and removes them from the cloud storage
*
* @param string $files The specific files
* @param mixed $data Anything passed back from self::backup()
* @param array $sizeinfo Size information
* @return Boolean - whether the operation succeeded or not
*/
8 years ago
public function delete($files, $data = false, $sizeinfo = array()) {
global $updraftplus;
if (is_string($files)) $files = array($files);
}
/**
* download method: takes a file name (base name), and brings it back from the cloud storage into Updraft's directory
* You can register errors with $updraftplus->log("my error message", 'error')
*
* @param string $file The specific file to be downloaded from the Cloud Storage
*/
8 years ago
public function download($file) {
global $updraftplus;
}
public function get_supported_features() {
// This options format is handled via only accessing options via $this->get_options()
return array('multi_options', 'config_templates');
}
8 years ago
/**
* Get the configuration template, in Handlebars format.
* Note that logging is not available from this context; it will do nothing.
*
* @return String - the template, ready for substitutions to be carried out
*/
public function get_configuration_template() {
ob_start();
$classes = $this->get_css_classes();
8 years ago
?>
<tr class="updraftplusmethod <?php echo $classes;?>">
<th>My Method:</th>
<td>
</td>
8 years ago
</tr>
<?php
return ob_get_clean();
8 years ago
}
}