summaryrefslogtreecommitdiffstats
path: root/apps/files_texteditor/ajax/savefile.php
blob: da3599b96c657c22c69a2b3d2922ff11160e4f35 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<?php
/**
 * ownCloud - Editor
 *
 * @author Tom Needham
 * @copyright 2011 Tom Needham contact@tomneedham.com
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU AFFERO GENERAL PUBLIC LICENSE for more details.
 *
 * You should have received a copy of the GNU Affero General Public
 * License along with this library.  If not, see <http://www.gnu.org/licenses/>.
 *
 */

// Init owncloud
require_once('../../../lib/base.php');


// Check if we are a user
OC_JSON::checkLoggedIn();

// Save the file data
$filecontents = htmlspecialchars_decode($_POST['filecontents']);
$file = $_POST['file'];
$dir = $_POST['dir'];
$path = $dir.'/'.$file;
//$force = isset($_POST['force']) ? $_POST['force'] : false;
//$sessionname = md5('oc_file_hash_'.$path);

function do_save($path,$filecontents){
	//$sessionname = md5('oc_file_hash_'.$path);
	//OC_Filesystem::update_session_file_hash($sessionname,md5(htmlspecialchars($filecontents)));
	OC_Filesystem::file_put_contents($path, $filecontents);
}
/*
// Check if file modified whilst editing?
if(isset($_SESSION[$sessionname])){
    if(!empty($_SESSION[$sessionname])){
        // Compare to current hash of file.
        $savedfilecontents = htmlspecialchars(OC_Filesystem::file_get_contents($path));
        $hash = md5($savedfilecontents);
        $originalhash = $_SESSION[$sessionname];
        // Compare with hash taken when file was opened
        if($hash != $originalhash){
            // Someone has played with the file while you were editing
            // Force save?
            if($force){
            	do_save($path, $filecontents);
            	OC_JSON::success();
            } else {	
            	// No force
            	OC_JSON::error(array('data' => array( 'message' => $l10n->t('The file has been edited since you opened it. Overwrite the file?'))));
            }
        } else  {
            // No body has edited it whilst you were, so save the file
            // Update the session hash.
            do_save($path,$filecontents);
            OC_JSON::success();
        }
        
        
}
} else {
    // No session value set for soem reason, just save the file.
	do_save($path,$filecontents);
	OC_JSON::success();
}
*/
do_save($path,$filecontents);
OC_JSON::success();