1
0
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:
Laurent Cozic 2017-01-05 19:01:50 +01:00
parent bb0af42fee
commit 96cd7d67b0
7 changed files with 328 additions and 12 deletions

View File

@ -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
View 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
View 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
View 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
View 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
View File

@ -0,0 +1,6 @@
<table>
<tr><th>Title</th></tr>
<?php foreach ($notes as $note): ?>
<tr><td><a href="/?action=notes&note_id=<?php echo $note['id']; ?>"><?php echo htmlentities($note['title']); ?></a></td></tr>
<?php endforeach; ?>
</table>

12
debug_client/views/page.php Executable file
View 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>