2018-07-13 18:39:55 +02:00
|
|
|
<?php
|
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) Codiad & Kent Safranski (codiad.com), distributed
|
|
|
|
* as-is and without warranty under the MIT License. See
|
|
|
|
* [root]/license.txt for more. This information must remain intact.
|
|
|
|
*/
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
require_once('../../common.php');
|
|
|
|
require_once('./class.project.php');
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
// Verify Session or Key
|
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
checkSession();
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
$Project = new Project();
|
2018-12-12 16:30:14 +01:00
|
|
|
$Project->projects = $Project->get_projects();
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2019-05-01 15:11:50 +02:00
|
|
|
if( ! is_array( $Project->projects ) ) {
|
|
|
|
|
|
|
|
$Project->projects = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-11-19 19:30:49 +01:00
|
|
|
if( $_GET['action'] == 'add_user' ) {
|
|
|
|
|
|
|
|
$invalid_users = array(
|
|
|
|
"",
|
|
|
|
"null",
|
|
|
|
"undefined"
|
|
|
|
);
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( ! isset( $_GET['access'] ) || in_array( $_GET['access'], $invalid_users ) || ! in_array( $_GET['access'], array_keys( Permissions::LEVELS ) ) ) {
|
2018-11-19 19:30:49 +01:00
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "No access set." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$access = Permissions::LEVELS[$_GET['access']];
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( isset( $_GET['user_id'] ) && ! in_array( $_GET['user_id'], $invalid_users ) ) {
|
2018-11-19 19:30:49 +01:00
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$user = $_GET['user_id'];
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "No user id set." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( isset( $_GET['project_path'] ) && $_GET['project_path'] != '' ) {
|
|
|
|
|
|
|
|
$project = $_GET['project_path'];
|
|
|
|
} else {
|
2018-11-19 19:30:49 +01:00
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "No project path set." ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( $Project->check_owner( $_GET['project_path'], true ) ) {
|
|
|
|
|
|
|
|
exit( json_encode( $Project->add_user( $project, $user, $access ) ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "You can not manage this project." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Create Project
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'create' ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$name = $_GET['project_name'];
|
|
|
|
$public = ( $_GET['public_project'] != 'true' ) ? false : true;
|
|
|
|
$path = ( $_GET['project_path'] != '' ) ? $_GET['project_path'] : $_GET['project_name'];
|
|
|
|
$return = $Project->Create( $path, $name, $public );
|
|
|
|
exit( json_encode( $return ) );
|
2018-07-13 18:39:55 +02:00
|
|
|
}
|
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
// Return Current
|
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-10-11 16:17:41 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'current' ) {
|
|
|
|
|
|
|
|
if( isset( $_SESSION['project'] ) ) {
|
|
|
|
|
|
|
|
echo formatJSEND( "success", $_SESSION['project'] );
|
|
|
|
} else {
|
|
|
|
|
|
|
|
echo formatJSEND( "error", "No Project Returned" );
|
|
|
|
}
|
2018-10-11 16:17:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Delete Project
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'delete' ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( isset( $_GET['project_path'] ) ) {
|
2018-11-10 06:41:28 +01:00
|
|
|
|
|
|
|
$Project->path = $_GET['project_path'];
|
|
|
|
$Project->Delete();
|
|
|
|
}
|
2018-07-13 18:39:55 +02:00
|
|
|
}
|
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Get Project Access
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'get_access' ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$access = $Project->get_access( $_GET['project_id'] );
|
2018-11-10 06:41:28 +01:00
|
|
|
echo formatJSEND( "success", $access );
|
2018-10-11 16:17:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Get Current Project
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
$no_return = false;
|
|
|
|
if( isset( $_GET['no_return'] ) ) {
|
|
|
|
|
|
|
|
$no_return = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( $_GET['action'] == 'get_current' ) {
|
|
|
|
|
|
|
|
if( ! isset( $_SESSION['project'] ) ) {
|
|
|
|
|
|
|
|
// Load default/first project
|
|
|
|
if( $no_return ) {
|
|
|
|
|
|
|
|
$Project->no_return = true;
|
|
|
|
}
|
2020-03-30 19:57:38 +02:00
|
|
|
$project = $Project->GetFirst();
|
|
|
|
|
|
|
|
if( $project == null ) {
|
|
|
|
|
|
|
|
exit( formatJSEND( "error", "Error, Could not load a projet." ) );
|
|
|
|
} else {
|
|
|
|
|
|
|
|
exit( formatJSEND( "success", $project ) );
|
|
|
|
}
|
2018-11-10 06:41:28 +01:00
|
|
|
} else {
|
|
|
|
|
|
|
|
// Load current
|
|
|
|
$Project->path = $_SESSION['project'];
|
|
|
|
$project_name = $Project->GetName();
|
|
|
|
if( ! $no_return ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "success", array( "name" => $project_name, "path" => $_SESSION['project'] ) ) );
|
2018-11-10 06:41:28 +01:00
|
|
|
}
|
|
|
|
}
|
2018-07-13 18:39:55 +02:00
|
|
|
}
|
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Check Project Owner
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'get_owner' ) {
|
|
|
|
|
|
|
|
$Project->path = $_GET['project_path'];
|
|
|
|
$owner = $Project->get_owner();
|
|
|
|
try {
|
|
|
|
|
|
|
|
$return = json_decode( $owner );
|
|
|
|
exit( formatJSEND( "error", null ) );
|
|
|
|
} catch( exception $e ) {
|
|
|
|
|
|
|
|
exit( formatJSEND( "success", array( "owner" => $owner ) ) );
|
|
|
|
}
|
2018-07-13 18:39:55 +02:00
|
|
|
}
|
|
|
|
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-11-10 06:41:28 +01:00
|
|
|
// Open Project
|
2018-10-11 16:17:41 +02:00
|
|
|
//////////////////////////////////////////////////////////////////
|
2018-07-13 18:39:55 +02:00
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
if( $_GET['action'] == 'open' ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( ! isset( $_GET['path'] ) || ! Permissions::has_read( $_GET['path'] ) ) {
|
2018-11-10 06:41:28 +01:00
|
|
|
|
|
|
|
die( formatJSEND( "error", "No Access to path " . $_GET['path'] ) );
|
|
|
|
}
|
|
|
|
$Project->path = $_GET['path'];
|
|
|
|
$Project->Open();
|
2018-10-11 16:17:41 +02:00
|
|
|
}
|
2018-11-10 06:41:28 +01:00
|
|
|
|
2018-11-19 19:30:49 +01:00
|
|
|
if( $_GET['action'] == 'remove_user' ) {
|
|
|
|
|
|
|
|
$invalid = array(
|
|
|
|
"",
|
|
|
|
"null",
|
|
|
|
"undefined"
|
|
|
|
);
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( isset( $_GET["project_path"] ) && ! in_array( $_GET['project_path'], $invalid ) ) {
|
2018-11-19 19:30:49 +01:00
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$Project->path = $_GET['project_path'];
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "No project path set." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( isset( $_GET["project_id"] ) && ! in_array( $_GET['project_id'], $invalid ) ) {
|
2018-11-19 19:30:49 +01:00
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$Project->project_id = $_GET['project_id'];
|
|
|
|
} else {
|
|
|
|
|
|
|
|
exit( formatJSEND( "error", "No project id set." ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
if( isset( $_GET["user_id"] ) && ! in_array( $_GET['user_id'], $invalid ) ) {
|
|
|
|
|
|
|
|
$user_id = $_GET["user_id"];
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "No user id set." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if( $Project->check_owner( $_GET["project_path"], true ) ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
$Project->remove_user( $user_id );
|
2018-11-19 19:30:49 +01:00
|
|
|
} else {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
exit( formatJSEND( "error", "You can not manage this project." ) );
|
2018-11-19 19:30:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-10 06:41:28 +01:00
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
// Rename Project
|
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
if( $_GET['action'] == 'rename' ) {
|
|
|
|
|
2020-03-30 19:57:38 +02:00
|
|
|
if( ! isset( $_GET['project_path'] ) || ! Permissions::has_owner( $_GET['project_path'] ) ) {
|
2018-11-10 06:41:28 +01:00
|
|
|
|
|
|
|
die( formatJSEND( "error", "No Access" ) );
|
|
|
|
}
|
|
|
|
$Project->path = $_GET['project_path'];
|
|
|
|
$Project->Rename();
|
2018-07-13 18:39:55 +02:00
|
|
|
}
|
2018-11-10 06:41:28 +01:00
|
|
|
|