mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-23 18:53:36 +02:00
Added debug client
This commit is contained in:
parent
bb0af42fee
commit
96cd7d67b0
@ -2,8 +2,7 @@ CREATE TABLE folders (
|
||||
id TEXT PRIMARY KEY,
|
||||
title TEXT,
|
||||
created_time INT,
|
||||
updated_time INT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
updated_time INT
|
||||
);
|
||||
|
||||
CREATE TABLE notes (
|
||||
@ -24,23 +23,20 @@ CREATE TABLE notes (
|
||||
todo_completed INT,
|
||||
source_application TEXT,
|
||||
application_data TEXT,
|
||||
`order` INT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
`order` INT
|
||||
);
|
||||
|
||||
CREATE TABLE tags (
|
||||
id TEXT PRIMARY KEY,
|
||||
title TEXT,
|
||||
created_time INT,
|
||||
updated_time INT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
updated_time INT
|
||||
);
|
||||
|
||||
CREATE TABLE note_tags (
|
||||
id INTEGER PRIMARY KEY,
|
||||
note_id TEXT,
|
||||
tag_id TEXT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
tag_id TEXT
|
||||
);
|
||||
|
||||
CREATE TABLE resources (
|
||||
@ -49,15 +45,13 @@ CREATE TABLE resources (
|
||||
mime TEXT,
|
||||
filename TEXT,
|
||||
created_time INT,
|
||||
updated_time INT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
updated_time INT
|
||||
);
|
||||
|
||||
CREATE TABLE note_resources (
|
||||
id INTEGER PRIMARY KEY,
|
||||
note_id TEXT,
|
||||
resource_id TEXT,
|
||||
synced BOOLEAN DEFAULT 0
|
||||
resource_id TEXT
|
||||
);
|
||||
|
||||
CREATE TABLE version (
|
||||
|
75
debug_client/css/style.css
Executable file
75
debug_client/css/style.css
Executable file
@ -0,0 +1,75 @@
|
||||
/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
|
||||
html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}
|
||||
body{margin:0}
|
||||
article,aside,footer,header,nav,section{display:block}
|
||||
h1{font-size:2em;margin:.67em 0}
|
||||
figcaption,figure,main{display:block}
|
||||
figure{margin:1em 40px}
|
||||
hr{box-sizing:content-box;height:0;overflow:visible}
|
||||
pre{font-family:monospace,monospace;font-size:1em}
|
||||
a{background-color:transparent;-webkit-text-decoration-skip:objects}
|
||||
a:active,a:hover{outline-width:0}
|
||||
abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}
|
||||
b,strong{font-weight:inherit;font-weight:bolder}
|
||||
code,kbd,samp{font-family:monospace,monospace;font-size:1em}
|
||||
dfn{font-style:italic}
|
||||
mark{background-color:#ff0;color:#000}
|
||||
small{font-size:80%}
|
||||
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
|
||||
sub{bottom:-.25em}
|
||||
sup{top:-.5em}
|
||||
audio,video{display:inline-block}
|
||||
audio:not([controls]){display:none;height:0}
|
||||
img{border-style:none}
|
||||
svg:not(:root){overflow:hidden}
|
||||
button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}
|
||||
button,input{overflow:visible}
|
||||
button,select{text-transform:none}
|
||||
button,html [type="button"],/* 1 */
|
||||
[type="reset"],[type="submit"]{-webkit-appearance:button}
|
||||
button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}
|
||||
button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}
|
||||
fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}
|
||||
legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}
|
||||
progress{display:inline-block;vertical-align:baseline}
|
||||
textarea{overflow:auto}
|
||||
[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}
|
||||
[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}
|
||||
[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}
|
||||
[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration{-webkit-appearance:none}
|
||||
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
|
||||
details,/* 1 */
|
||||
menu{display:block}
|
||||
summary{display:list-item}
|
||||
canvas{display:inline-block}
|
||||
template{display:none}
|
||||
[hidden]{display:none}
|
||||
/*! normalize.css v5.0.0 | MIT License | github.com/necolas/normalize.css */
|
||||
|
||||
body {
|
||||
padding: 1em;
|
||||
}
|
||||
|
||||
table {
|
||||
border-spacing: 0;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
td {
|
||||
border: 1px #ccc solid;
|
||||
padding: .3em;
|
||||
}
|
||||
|
||||
.form-group {
|
||||
margin-bottom: 0.5em;
|
||||
}
|
||||
|
||||
.form-group label {
|
||||
width: 200px;
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.form-group input {
|
||||
width: 300px;
|
||||
display: inline-block;
|
||||
}
|
190
debug_client/index.php
Executable file
190
debug_client/index.php
Executable file
@ -0,0 +1,190 @@
|
||||
<?php
|
||||
|
||||
function initialize() {
|
||||
ini_set('display_errors', 1);
|
||||
ini_set('display_startup_errors', 1);
|
||||
error_reporting(E_ALL);
|
||||
|
||||
session_start();
|
||||
|
||||
unset($_SESSION['sessionId']);
|
||||
}
|
||||
|
||||
function config($name) {
|
||||
$config = array(
|
||||
'baseUrl' => 'http://joplin.local',
|
||||
'clientId' => 'E3E3E3E3E3E3E3E3E3E3E3E3E3E3E3E3',
|
||||
);
|
||||
if (isset($config[$name])) return $config[$name];
|
||||
throw new Exception('Unknown config: ' . $name);
|
||||
}
|
||||
|
||||
function curlCmd($method, $url, $data) {
|
||||
$cmd = array();
|
||||
$cmd[] = 'curl';
|
||||
if ($method != 'GET' && $method != 'POST') {
|
||||
$cmd[] = '-X ' . $method;
|
||||
}
|
||||
if ($method != 'GET' && $method != 'DELETE') {
|
||||
$cmd[] = "--data '" . http_build_query($data) . "'";
|
||||
}
|
||||
$cmd[] = "'" . $url . "'";
|
||||
|
||||
return implode(' ', $cmd);
|
||||
}
|
||||
|
||||
function saveCurlCmd($cmd) {
|
||||
$cmds = array();
|
||||
if (isset($_SESSION['curlCommands'])) $cmds = $_SESSION['curlCommands'];
|
||||
$cmds[] = $cmd;
|
||||
while (count($cmds) > 100) {
|
||||
array_splice($cmds, 0, 1);
|
||||
}
|
||||
$_SESSION['curlCommands'] = $cmds;
|
||||
}
|
||||
|
||||
function execRequest($method, $path, $query = array(), $data = null) {
|
||||
$url = config('baseUrl') . '/' . $path;
|
||||
if (!empty($_SESSION['sessionId'])) {
|
||||
$query['session'] = $_SESSION['sessionId'];
|
||||
}
|
||||
if (count($query)) $url .= '?' . http_build_query($query);
|
||||
|
||||
$ch = curl_init();
|
||||
curl_setopt($ch, CURLOPT_URL, $url);
|
||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
||||
if ($data) curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
|
||||
if ($method != 'GET' && $method != 'POST') {
|
||||
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);
|
||||
}
|
||||
$response = curl_exec($ch);
|
||||
curl_close($ch);
|
||||
|
||||
$curlCmd = curlCmd($method, $url, $data);
|
||||
saveCurlCmd($curlCmd);
|
||||
|
||||
$output = json_decode($response, true);
|
||||
if ($output === null) {
|
||||
$msg = 'Cannot decode JSON: ' . $response . "\n\n" . $curlCmd;
|
||||
die($msg);
|
||||
}
|
||||
|
||||
return $output;
|
||||
}
|
||||
|
||||
function renderView($name, $parameters = array()) {
|
||||
$path = dirname(__FILE__) . '/views/' . $name . '.php';
|
||||
if (!file_exists($path)) throw new Exception('View not found: ' . $path);
|
||||
|
||||
extract($parameters);
|
||||
ob_start();
|
||||
include $path;
|
||||
$content = ob_get_contents();
|
||||
ob_end_clean();
|
||||
return $content;
|
||||
}
|
||||
|
||||
function differentProperties($old, $new, $oldPrefix = '') {
|
||||
$output = array();
|
||||
foreach ($old as $k1 => $v1) {
|
||||
foreach ($new as $k2 => $v2) {
|
||||
if ($k1 === $k2 && (string)$v1 !== (string)$v2) {
|
||||
$output[$k1] = $v2;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
function removePrefix($array, $prefix) {
|
||||
$output = array();
|
||||
foreach ($array as $k => $v) {
|
||||
if (strpos($k, $prefix) === 0) {
|
||||
$k = substr($k, strlen($prefix));
|
||||
}
|
||||
$output[$k] = $v;
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
function redirect($path) {
|
||||
header('Location: ' . $path);
|
||||
die();
|
||||
}
|
||||
|
||||
initialize();
|
||||
|
||||
$session = execRequest('POST', 'sessions', null, array(
|
||||
'email' => 'laurent@cozic.net',
|
||||
'password' => '12345678',
|
||||
'client_id' => config('clientId'),
|
||||
));
|
||||
|
||||
$_SESSION['sessionId'] = $session['id'];
|
||||
|
||||
$action = isset($_GET['action']) ? $_GET['action'] : 'folders';
|
||||
|
||||
if (isset($_POST['create_folder'])) $action = 'create_folder';
|
||||
if (isset($_POST['delete_folder'])) $action = 'delete_folder';
|
||||
if (isset($_POST['update_folder'])) $action = 'update_folder';
|
||||
|
||||
$pageParams = array(
|
||||
'title' => ucfirst($action),
|
||||
'contentHtml' => '',
|
||||
);
|
||||
|
||||
switch ($action) {
|
||||
|
||||
case 'folders':
|
||||
|
||||
$folders = execRequest('GET', 'folders');
|
||||
$pageParams['contentHtml'] = renderView('folders', array('folders' => $folders));
|
||||
break;
|
||||
|
||||
case 'folder':
|
||||
|
||||
$folder = execRequest('GET', 'folders/' . $_GET['folder_id']);
|
||||
$pageParams['contentHtml'] = renderView('folder', array('folder' => $folder));
|
||||
break;
|
||||
|
||||
case 'notes':
|
||||
|
||||
$notes = execRequest('GET', 'folders/' . $_GET['folder_id'] . '/notes');
|
||||
$pageParams['contentHtml'] = renderView('notes', array('notes' => $notes));
|
||||
break;
|
||||
|
||||
case 'create_folder':
|
||||
|
||||
$data = array('title' => $_POST['folder_title']);
|
||||
$folder = execRequest('POST', 'folders', null, $data);
|
||||
redirect('/');
|
||||
break;
|
||||
|
||||
case 'delete_folder':
|
||||
|
||||
$folder = execRequest('DELETE', 'folders/' . $_POST['folder_id']);
|
||||
redirect('/');
|
||||
break;
|
||||
|
||||
case 'update_folder':
|
||||
|
||||
$oldFolder = json_decode($_POST['original_folder'], true);
|
||||
$newFolder = removePrefix($_POST, 'folder_');
|
||||
$diff = differentProperties($oldFolder, $newFolder);
|
||||
if (count($diff)) {
|
||||
execRequest('PATCH', 'folders/' . $_POST['folder_id'], null, $diff);
|
||||
}
|
||||
redirect('/');
|
||||
break;
|
||||
|
||||
}
|
||||
|
||||
echo renderView('page', $pageParams);
|
||||
|
||||
echo '<pre style="color: #777; font-family: monospace;">';
|
||||
$curlCommands = isset($_SESSION['curlCommands']) ? $_SESSION['curlCommands'] : array();
|
||||
for ($i = count($curlCommands) - 1; $i >= 0; $i--) {
|
||||
$cmd = $curlCommands[$i];
|
||||
echo $cmd . "\n";
|
||||
}
|
||||
echo '</pre>';
|
10
debug_client/views/folder.php
Executable file
10
debug_client/views/folder.php
Executable file
@ -0,0 +1,10 @@
|
||||
<form method="post">
|
||||
<?php foreach ($folder as $k => $v): ?>
|
||||
<div class="form-group">
|
||||
<label><?php echo htmlentities($k); ?></label>
|
||||
<input type="text" class="form-control" name="folder_<?php echo htmlentities($k); ?>" value="<?php echo htmlentities($v); ?>" >
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<input type="hidden" value="<?php echo htmlentities(json_encode($folder)); ?>" name="original_folder" />
|
||||
<input type="submit" value="Save" name="update_folder" />
|
||||
</form>
|
29
debug_client/views/folders.php
Executable file
29
debug_client/views/folders.php
Executable file
@ -0,0 +1,29 @@
|
||||
<table>
|
||||
<tr><th>Title</th><th></th><th></th></tr>
|
||||
<?php foreach ($folders as $folder): ?>
|
||||
<tr>
|
||||
<td>
|
||||
<a href="/?action=folder&folder_id=<?php echo $folder['id']; ?>"><?php echo htmlentities($folder['title']); ?></a>
|
||||
</td>
|
||||
<td>
|
||||
<a href="/?action=notes&folder_id=<?php echo $folder['id']; ?>">View notes</a>
|
||||
</td>
|
||||
<td>
|
||||
<form method="post">
|
||||
<input type="hidden" value="<?php echo htmlentities($folder['id']); ?>" name="folder_id">
|
||||
<input type="submit" value="Delete" name="delete_folder" />
|
||||
</form>
|
||||
</td>
|
||||
</tr>
|
||||
<?php endforeach; ?>
|
||||
</table>
|
||||
|
||||
<hr/>
|
||||
|
||||
<form method="post">
|
||||
<div class="form-group">
|
||||
<label for="folder_title">Folder title</label>
|
||||
<input type="text" class="form-control" name="folder_title" >
|
||||
</div>
|
||||
<input type="submit" value="Create" name="create_folder" />
|
||||
</form>
|
6
debug_client/views/notes.php
Executable file
6
debug_client/views/notes.php
Executable file
@ -0,0 +1,6 @@
|
||||
<table>
|
||||
<tr><th>Title</th></tr>
|
||||
<?php foreach ($notes as $note): ?>
|
||||
<tr><td><a href="/?action=notes¬e_id=<?php echo $note['id']; ?>"><?php echo htmlentities($note['title']); ?></a></td></tr>
|
||||
<?php endforeach; ?>
|
||||
</table>
|
12
debug_client/views/page.php
Executable file
12
debug_client/views/page.php
Executable file
@ -0,0 +1,12 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title><?php echo htmlentities($title); ?></title>
|
||||
<link rel="stylesheet" type="text/css" href="/css/style.css">
|
||||
</head>
|
||||
<body>
|
||||
<a href="/">Home</a>
|
||||
<h1><?php echo htmlentities($title); ?></h1>
|
||||
<?php echo $contentHtml; ?>
|
||||
</body>
|
||||
</head>
|
Loading…
x
Reference in New Issue
Block a user