123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- <?php
- /*
- FusionPBX
- Version: MPL 1.1
- The contents of this file are subject to the Mozilla Public License Version
- 1.1 (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
- http://www.mozilla.org/MPL/
- Software distributed under the License is distributed on an "AS IS" basis,
- WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
- for the specific language governing rights and limitations under the
- License.
- The Original Code is FusionPBX
- The Initial Developer of the Original Code is
- Mark J Crane <[email protected]>
- Portions created by the Initial Developer are Copyright (C) 2008-2023
- the Initial Developer. All Rights Reserved.
- Contributor(s):
- Mark J Crane <[email protected]>
- */
- //includes files
- require_once dirname(__DIR__, 2) . "/resources/require.php";
- require_once "resources/check_auth.php";
- //check permissions
- if (permission_exists('edit_view')) {
- //access granted
- }
- else {
- echo "access denied";
- exit;
- }
- //get the directory
- if (!isset($_SESSION)) { session_start(); }
- switch ($_SESSION["app"]["edit"]["dir"]) {
- case 'scripts':
- $edit_directory = $_SESSION['switch']['scripts']['dir'];
- break;
- case 'php':
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].'/'.PROJECT_PATH;
- break;
- case 'grammar':
- $edit_directory = $_SESSION['switch']['grammar']['dir'];
- break;
- case 'provision':
- switch (PHP_OS) {
- case "Linux":
- if (file_exists('/usr/share/fusionpbx/templates/provision')) {
- $edit_directory = '/usr/share/fusionpbx/templates/provision';
- }
- elseif (file_exists('/etc/fusionpbx/resources/templates/provision')) {
- $edit_directory = '/etc/fusionpbx/resources/templates/provision';
- }
- else {
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/resources/templates/provision";
- }
- break;
- case "FreeBSD":
- if (file_exists('/usr/local/share/fusionpbx/templates/provision')) {
- $edit_directory = '/usr/share/fusionpbx/templates/provision';
- }
- elseif (file_exists('/usr/local/etc/fusionpbx/resources/templates/provision')) {
- $edit_directory = '/usr/local/etc/fusionpbx/resources/templates/provision';
- }
- else {
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/resources/templates/provision";
- }
- break;
- case "NetBSD":
- if (file_exists('/usr/local/share/fusionpbx/templates/provision')) {
- $edit_directory = '/usr/share/fusionpbx/templates/provision';
- }
- else {
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/resources/templates/provision";
- }
- break;
- case "OpenBSD":
- if (file_exists('/usr/local/share/fusionpbx/templates/provision')) {
- $edit_directory = '/usr/share/fusionpbx/templates/provision';
- }
- else {
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/resources/templates/provision";
- }
- break;
- default:
- $edit_directory = $_SERVER["DOCUMENT_ROOT"].PROJECT_PATH."/resources/templates/provision/";
- }
- break;
- case 'xml':
- $edit_directory = $_SESSION['switch']['conf']['dir'];
- break;
- }
- if (!isset($edit_directory) && is_array($_SESSION['editor']['path'])) {
- foreach ($_SESSION['editor']['path'] as $path) {
- if ($_SESSION["app"]["edit"]["dir"] == $path) {
- $edit_directory = $path;
- break;
- }
- }
- }
- //set the file variable
- $file_name = $_POST["file"];
- //remove attempts to change the directory
- $file_name = str_replace('..', '', $file_name);
- $file_name = str_replace ("\\", "/", $file_name);
- //break the path into an array
- $path_array = pathinfo($file_name);
- $path_prefix = substr($path_array['dirname'], 0, strlen($edit_directory));
- //validate the path
- if (realpath($path_prefix) == realpath($edit_directory)) {
- //clear the output
- ob_clean();
- //send the content of the file
- echo file_get_contents($file_name);
- //get the contents of the file
- /*
- $handle = fopen($file_name, "r");
- if ($handle) {
- while (!feof($handle)) {
- $buffer = fgets($handle, 4096);
- echo $buffer;
- }
- fclose($handle);
- }
- */
- }
|