diff options
Diffstat (limited to 'app/class')
-rw-r--r-- | app/class/aff.php | 1018 | ||||
-rw-r--r-- | app/class/app4.php | 657 | ||||
-rw-r--r-- | app/class/application.php | 5 | ||||
-rw-r--r-- | app/class/config.php | 4 | ||||
-rw-r--r-- | app/class/controller.php | 3 | ||||
-rw-r--r-- | app/class/controllermedia.php | 17 | ||||
-rw-r--r-- | app/class/modelmedia.php | 1 | ||||
-rw-r--r-- | app/class/modeluser.php | 43 | ||||
-rw-r--r-- | app/class/w.article.php | 32 | ||||
-rw-r--r-- | app/class/w.home.php | 85 | ||||
-rw-r--r-- | app/class/w.menu.php | 56 |
11 files changed, 41 insertions, 1880 deletions
diff --git a/app/class/aff.php b/app/class/aff.php deleted file mode 100644 index 6f9f07e..0000000 --- a/app/class/aff.php +++ /dev/null @@ -1,1018 +0,0 @@ -<?php - -class Aff -{ - - - // ____________________________________________________ C O N F I G ______________________________________________ - - - public function configform() - { - ?> - <p>Config file does not exist yet, or maybe you deleted it ? Anyway, it is time to set it :</p> - <form action="" method="post"> - <input type="hidden" name="config" value="create"> - Database settings</br> - <input type="text" name="host" id="" placeholder="host"></br> - <input type="text" name="dbname" id="" placeholder="dbname"></br> - <input type="text" name="user" id="" placeholder="user"></br> - <input type="text" name="password" id="" placeholder="password"></br> - Domain name settings</br> - <input type="text" name="domain" id="" placeholder="domain"></br> - W_cms settings</br> - <input type="text" name="admin" id="" placeholder="W admin password" required></br> - <input type="hidden" name="editor" id="" value="editor"> - <input type="hidden" name="invite" id="" value="invite"> - <input type="hidden" name="read" id="" value="read"> - <input type="hidden" name="cssread" id="" value=""> - (You can change everything later, set at least your admin password, and don't forget it !)</br> - <input type="submit" value="create config file"> - </form> - <?php - - } - - - - - - - - // ____________________________________________________ F U N ______________________________________________ - - - - - - - - public function edit(Art2 $art, App $app, $list, $fontsize, $imagelist) - { - - if ($app->session() >= $app::EDITOR) { - - ?> - - <form action="?id=<?= $art->id() ?>" method="post" id="artedit"> - - <?php - echo '<style>textarea{font-size: ' . $fontsize . '}</style>'; - $tablist = ['section' => $art->md(), 'css' => $art->css(), 'aside' => $art->aside(), 'footer' => $art->footer()]; - - $this->tabs($tablist, 'section'); - - ?> - - <div id="submit"> - <input type="submit" name="action" value="home" accesskey="w" onclick="document.getElementById('artedit').submit();" form="artedit"> - <input type="submit" name="action" value="update" accesskey="x" onclick="document.getElementById('artedit').submit();" form="artedit"> - <input type="submit" name="action" value="display" accesskey="c" onclick="document.getElementById('artedit').submit();" form="artedit"> - <input type="submit" name="action" value="delete" onclick="confirmSubmit(event, 'Delete this article', 'artedit')" form="artedit"> - <a href="?id=<?= $art->id() ?>" target="_blank">👁</a> - - <span id="headid"><?= $art->id() ?></span> - - <label for="fontsize">Font-size</label> - <input type="number" name="fontsize" value="<?= $fontsize ?>" id="fontsize"> - </div> - <div class="sidebar"> - <details id="editinfo" open> - <summary>Infos</summary> - <fieldset> - <label for="title">title :</label> - <input type="text" name="title" id="title" value="<?= $art->title(); ?>"> - <label for="description">Description :</label> - <input type="text" name="description" id="description" value="<?= $art->description(); ?>"> - <label for="tag">Tag(s) :</label> - <input type="text" name="tag" id="tag" value="<?= $art->tag('string'); ?>"> - <label for="secure">Niveau de sécurité :</label> - <select name="secure" id="secure"> - <option value="0" <?= $art->secure() == 0 ? 'selected' : '' ?>>0</option> - <option value="1" <?= $art->secure() == 1 ? 'selected' : '' ?>>1</option> - <option value="2" <?= $art->secure() == 2 ? 'selected' : '' ?>>2</option> - </select> - <label for="template">Template :</label> - <select name="template" id="template"> - <?php - if ($art->template() == 'NULL') { - echo '<option value="" selected >No template</option>'; - } else { - echo '<option value="" >No template</option>'; - } - foreach ($list as $item) { - - if ($item->id() == $art->template()) { - echo '<option value="' . $item->id() . '" selected >' . $item->title() . '</option>'; - } else { - echo '<option value="' . $item->id() . '">' . $item->title() . '</option>'; - } - } - ?> - </select> - </fieldset> - </details> - <details> - <summary>Advanced</summary> - <fieldset> - <h3>Template options</h3> - <p>NOT WORKING</p> - </fieldset> - </details> - <details id="editcss" open> - <summary>Quick CSS</summary> - - </details> - <details> - <summary>Help</summary> - <div id="help"> - <?= $this->editorhelp() ?> - </div> - </details> - - - </div> - - - <input type="hidden" name="datecreation" value="<?= $art->datecreation('string'); ?>"> - <input type="hidden" name="id" value="<?= $art->id() ?>"> - - </form> - - - <?php - -} - -} - - -public function tabs($tablist, $opentab) -{ - echo '<div class="tabs">'; - foreach ($tablist as $key => $value) { - echo '<div class="tab">'; - if ($key == $opentab) { - echo '<input name="checkbox-tabs-group" type="radio" id="tab' . $key . '" class="checkboxtab" checked>'; - } else { - echo '<input name="checkbox-tabs-group" type="radio" id="tab' . $key . '" class="checkboxtab">'; - } - echo '<label for="tab' . $key . '">' . $key . '</label>'; - echo '<div class="content">'; - echo '<textarea name="' . $key . '" id="' . $key . '" >' . $value . '</textarea>'; - echo '</div>'; - echo '</div>'; - } - - echo '</div>'; -} - -public function editorhelp() -{ - ?> - <h2>Help !</h2> - <p>To save your article, press the HOME, UPDATE, or DISPLAY buttons. You can use the keyboard shortcuts as well.</p> - <pre><span class="i">ALT + W</span> : home</pre> - <pre><span class="i">ALT + X</span> : update</pre> - <pre><span class="i">ALT + C</span> : display</pre> - <h3>Markdown</h3> - <p>The html section use <a href="https://daringfireball.net/projects/markdown/syntax" target="_blank">Markdown encoding</a>. Actualy, W is using Michel Fortin's <a href="https://michelf.ca/projects/php-markdown/extra/" target="_blank">Markdown Extra</a>.</p> - <h3>Links</h3> - <pre>[text](=<span class="i">article_id</span>)</pre> - <p>where article_id is the article's id you want to point to.</p> - <h3>Images</h3> - <pre>[altimage](/<span class="i">img_id.extension</span>)</pre> - <p>Where img_id is the id of your image and its extension.</p> - <h3>Shortcuts</h3> - <pre>%TITLE%</pre> - <p>Show the title of your article.</p> - <pre>%DESCRIPTION%</pre> - <p>Show the description of your article.</p> - <pre>%SUMMARY%</pre> - <p>Generate a <strong>summary</strong>, the list of all your head titles using #, ##, ###...</p> - <pre>%%<span class="i">tag_name</span>%%</pre> - <p>Generate a <strong>menu</strong>, a list of links to all articles under this tag.</p> - <p>vv</p> - <p>vv</p> - <p>vv</p> - <p></p> - <?php -} - - - -public function head($title, $tool, $color4) -{ - ?> - <head> - <meta charset="utf8" /> - <meta name="viewport" content="width=device-width" /> - <link rel="shortcut icon" href="./media/logo.png" type="image/x-icon"> - <link href="./rsc/css/stylebase.css" rel="stylesheet" /> - <link href="./rsc/css/style<?= $tool ?>.css" rel="stylesheet" /> - <style> - :root { - --color4: <?= $color4 ?>; - } - </style> - <title><?= $title ?></title> - <script src="./rsc/js/app.js"></script> - </head> - <?php - -} - -public function arthead(Art2 $art, $globalcss, $edit = 0) -{ - ?> - <head> - <meta charset="utf8" /> - <meta name="description" content="<?= $art->description() ?>" /> - <meta name="viewport" content="width=device-width" /> - <link rel="shortcut icon" href="./media/logo.png" type="image/x-icon"> - <link href="./rsc/css/stylebase.css" rel="stylesheet" /> - <?= $edit == 0 ? '<link href="' . $globalcss . '" rel="stylesheet" />' : '<link href="./rsc/css/styleedit.css" rel="stylesheet" />' ?> - <title><?= $edit == 1 ? '✏' : '' ?> <?= $art->title() ?></title> - <script src="./rsc/js/app.js"></script> - </head> - <?php - -} - -public function noarthead($id, $globalcss) -{ - ?> - <head> - <meta charset="utf8" /> - <meta name="description" content="This article does not exist yet." /> - <meta name="viewport" content="width=device-width" /> - <link rel="shortcut icon" href="./media/logo.png" type="image/x-icon"> - <link href="./rsc/css/stylebase.css" rel="stylesheet" /> - <link href="<?= $globalcss ?>" rel="stylesheet" /> - <title>❓ <?= $id ?></title> - <script src="./rsc/js/app.js"></script> - </head> - <?php - -} - - - - -public function search() -{ - ?> - <div id="search"> - <form action="./" method="get"> - <input type="text" name="id" id="id" placeholder="identifiant article" required> - <input type="submit" value="accéder"> - </form> - </div> - <?php - -} - -public function tag($getlist, $tag, $app) -{ - echo '<div class="tag">'; - echo '<ul>'; - foreach ($getlist as $item) { - if (in_array($tag, $item->tag('array'))) { - echo '<li><a href="?id=' . $item->id() . '">' . $item->title() . '</a> - ' . $item->description(); - if ($app->session() >= $app::EDITOR) { - echo ' - <a href="?id=' . $item->id() . '&edit=1">modifier</a></li>'; - } else { - echo '</li>'; - } - } - } - echo ' </ul> '; - echo ' </div> '; -} - -public function linkfrom($getlist, $linkfrom, App $app) -{ - echo '<div class="linkfrom">'; - echo '<ul>'; - foreach ($getlist as $item) { - if (in_array($linkfrom, $item->linkfrom('array'))) { - echo '<li><a href="?id=' . $item->id() . '">' . $item->title() . '</a> - ' . $item->description(); - if ($app->session() >= $app::EDITOR) { - echo ' - <a href="?id=' . $item->id() . '&edit=1">modifier</a> - <a href="?linkfrom=' . $item->id() . '">linkfroms</a></li>'; - } else { - echo '</li>'; - } - } - } - echo ' </ul> '; - echo ' </div> '; -} - -public function dump($getlist) -{ - echo '<ul>'; - foreach ($getlist as $item) { - echo '<li>'; - var_dump($item); - echo '</li>'; - } - echo ' </ul> '; -} - -public function header() -{ - echo '<header>'; - $this->search(); - echo '</header>'; -} - - -public function home2table(App $app, $getlist, $masslist) -{ - echo '<div id="main">'; - echo '<h2>Articles</h2>'; - echo '<form action="./" method="post">'; - - ?> - <div id="massedit"> - <h3>Mass Edit</h3> - <select name="massedit" required> - <option value="public">set as public</option> - <option value="private">set as private</option> - <option value="not published">set as not published</option> - <option value="erasetag">erase all tags</option> - <option value="erasetemplate">erase template</option> - <option value="delete">delete</option> - </select> - - <input type="submit" name="massaction" value="do" onclick="confirmSubmit(event, 'Are you sure')" > - - <input type="text" name="targettag" placeholder="add tag"> - <input type="submit" name="massaction" value="add tag" onclick="confirmSubmit(event, 'Are you sure')" > - - <select name="masstemplate"> - <?php - foreach ($masslist as $art) { - echo '<option value="' . $art->id() . '">' . $art->id() . '</option>'; - } - ?> - </select> - - <input type="submit" name="massaction" value="set template" onclick="confirmSubmit(event, 'Are you sure')" > - - <input type="hidden" name="action" value="massedit"> - </div> - - <?php - if ($app->session() >= $app::EDITOR) { - echo '<table id="home2table">'; - echo '<tr><th>x</th><th>title</th><th>tag</th><th>summary</th><th>↘ to</th><th>↗ from</th><th>last modification</th><th>date of creation</th><th>privacy</th><th>display</th></tr>'; - foreach ($getlist as $item) { - echo '<tr>'; - echo '<td><input type="checkbox" name="id[]" value=' . $item->id() . '></td>'; - echo '<td><a href="?id=' . $item->id() . '&edit=1">' . $item->title() . '</a></td>'; - echo '<td>' . $item->tag('sort') . '</td>'; - echo '<td>' . $item->description() . '</td>'; - echo '<td><a href="?linkfrom=' . $item->id() . '">' . $item->linkto('sort') . '</a></td>'; - echo '<td>' . $item->linkfrom('sort') . '</td>'; - echo '<td>' . $item->datemodif('hrdi') . '</td>'; - echo '<td>' . $item->datecreation('hrdi') . '</td>'; - echo '<td>' . $item->secure('string') . '</td>'; - echo '<td><a href="?id=' . $item->id() . '" target="_blank">👁</a></td>'; - echo '</tr>'; - } - echo ' </table> '; - echo ' </form> '; - echo '</div>'; - } -} - -public function option(App $app, Opt $opt) -{ - if ($app->session() >= $app::EDITOR) { - echo '<div id="options">'; - echo '<h2>Options</h2>'; - echo '<form action="./" method="get" >'; - echo '<input type="submit" name="submit" value="filter">'; - echo '⬅<input type="submit" name="submit" value="reset">'; - - - $this->optionsort($opt); - $this->optionprivacy($opt); - $this->optiontag($opt); - - if ($opt->invert() == 1) { - echo '<input type="checkbox" name="invert" value="1" id="invert" checked>'; - } else { - echo '<input type="checkbox" name="invert" value="1" id="invert">'; - } - echo '<label for="invert">invert</></br>'; - - - echo '<input type="submit" name="submit" value="filter">'; - echo '⬅<input type="submit" name="submit" value="reset">'; - - echo '</form></div>'; - - } - -} - -public function optiontag(Opt $opt) -{ - - echo '<fieldset><legend>Tag</legend><ul>'; - - - echo '<input type="radio" id="OR" name="tagcompare" value="OR" ' . ($opt->tagcompare() == "OR" ? "checked" : "") . ' ><label for="OR">OR</label>'; - echo '<input type="radio" id="AND" name="tagcompare" value="AND" ' . ($opt->tagcompare() == "AND" ? "checked" : "") . '><label for="AND">AND</label>'; - - //echo '<input type="hidden" name="tagfilter[]" value="">'; - - $in = false; - $out = false; - $limit = 1; - foreach ($opt->taglist() as $tagfilter => $count) { - - if ($count > $limit && $in == false) { - echo '<details open><summary>>' . $limit . '</summary>'; - $in = true; - } - if ($count == $limit && $in == true && $out == false) { - echo '</details><details><summary>' . $limit . '</summary>'; - $out = true; - } - - if (in_array($tagfilter, $opt->tagfilter())) { - - echo '<li><input type="checkbox" name="tagfilter[]" id="' . $tagfilter . '" value="' . $tagfilter . '" checked /><label for="' . $tagfilter . '">' . $tagfilter . ' (' . $count . ')</label></li>'; - } else { - echo '<li><input type="checkbox" name="tagfilter[]" id="' . $tagfilter . '" value="' . $tagfilter . '" /><label for="' . $tagfilter . '">' . $tagfilter . ' (' . $count . ')</label></li>'; - } - } - if ($in = true || $out = true) { - echo '</details>'; - } - echo '</ul></fieldset>'; - -} - -public function optionprivacy(Opt $opt) -{ - echo '<fieldset><legend>Privacity</legend><ul>'; - echo '<li><input type="radio" id="4" name="secure" value="4" ' . ($opt->secure() == 4 ? "checked" : "") . ' /><label for="4">all</label></li>'; - echo '<li><input type="radio" id="2" name="secure" value="2" ' . ($opt->secure() == 2 ? "checked" : "") . ' /><label for="2">not published</label></li>'; - echo '<li><input type="radio" id="1" name="secure" value="1" ' . ($opt->secure() == 1 ? "checked" : "") . ' /><label for="1">private</label></li>'; - echo '<li><input type="radio" id="0" name="secure" value="0" ' . ($opt->secure() == 0 ? "checked" : "") . ' /><label for="0">public</label></li>'; - echo '</ul></fieldset>'; -} - -public function optionsort(Opt $opt) -{ - echo '<fieldset><legend>Sort</legend>'; - echo '<select name="sortby" id="sortby">'; - foreach ($opt->col('array') as $key => $col) { - echo '<option value="' . $col . '" ' . ($opt->sortby() == $col ? "selected" : "") . '>' . $col . '</option>'; - } - echo '</select>'; - echo '</br>'; - echo '<input type="radio" id="asc" name="order" value="1" ' . ($opt->order() == '1' ? "checked" : "") . ' /><label for="asc">ascending</label>'; - echo '</br>'; - echo '<input type="radio" id="desc" name="order" value="-1" ' . ($opt->order() == '-1' ? "checked" : "") . ' /><label for="desc">descending</label>'; - - echo '</fieldset>'; - -} - -public function mapheader() -{ - $selectcurve = isset($_GET['curve']) ? $_GET['curve'] : 'basis'; - $selectorient = isset($_GET['orient']) ? $_GET['orient'] : 'TD'; - $curves = ['linear', 'basis', 'natural', 'step', 'stepAfter', 'stepBefore', 'monotoneX', 'monotoneY']; - $orients = ['TD', 'LR', 'BT', 'RL']; - ?> - <h2>Map</h2> - - <form action="./" method="get"> - <label for="curve">Curve style</label> - <select name="curve" id="curve"> - <?php - foreach ($curves as $curve) { - ?> - <option value="<?= $curve ?>" <?= $selectcurve == $curve ? 'selected' : '' ?>><?= $curve ?></option> - <?php - - } - ?> - </select> - <label for="orient">Orientation</label> - <select name="orient" id="orient"> - <?php - foreach ($orients as $orient) { - ?> - <option value="<?= $orient ?>" <?= $selectorient == $orient ? 'selected' : '' ?>><?= $orient ?></option> - <?php - - } - ?> - </select> - <input type="submit" value="draw" name="map"> - </form> - <?php - -} - -public function mermaid(string $map) -{ - $curve = isset($_GET['curve']) ? $_GET['curve'] : 'basis'; - $orient = isset($_GET['orient']) ? $_GET['orient'] : 'TD'; - - - ?> - - <script src="./rsc/js/mermaid.min.js"></script> - - <script> - mermaid.initialize({ - startOnLoad:true, - themeCSS: ".node circle, .node rect , .node polygon { fill: var(--color1); stroke: var(--color4);} ", - flowchart: { - curve: '<?= $curve ?>' - } - }); - - </script> - - - <div class="mermaid"> - - graph <?= $orient ?> - <?= $map ?> - </div> - - - <?php - -} - -public function aside(App $app) -{ - if ($app->session() >= $app::EDITOR) { - echo '<div id="linklist">Links<div id="roll"><ul>'; - foreach ($app->lister() as $item) { - echo '<li><a href="?id=' . $item['id'] . '&edit=1">' . $item['title'] . '</a> - <input type="text" value="[' . $item['title'] . '](?id=' . $item['id'] . ')">'; - - - } - echo ' </ul></div></div> '; - } -} - -public function nav($app) -{ - echo '<nav>'; - echo $app->session(); - echo '<div id="menu">'; - - echo '<a class="button" href="?">home</a>'; - - if ($app->session() == $app::FREE) { - if (isset($_GET['id'])) { - echo '<form action="./?id=' . $_GET['id'] . '" method="post">'; - } else { - echo '<form action="." method="post">'; - } - ?> - <input type="hidden" name="action" value="login"> - <input type="password" name="pass" id="loginpass" placeholder="password"> - <input type="submit" value="login"> - </form> - <?php - - } - if ($app->session() > $app::FREE) { - if (isset($_GET['id'])) { - echo '<form action="./?id=' . $_GET['id'] . '" method="post">'; - } else { - echo '<form action="." method="post">'; - } - ?> - <input type="hidden" name="action" value="logout"> - <input type="submit" value="logout"> - </form> - <?php - - } - if ($app->session() >= $app::EDITOR && isset($_GET['id']) && $app->exist($_GET['id'])) { - if (isset($_GET['edit']) && $_GET['edit'] == 1) { - echo '<a class="button" href="?id=' . $_GET['id'] . '" target="_blank">display</a>'; - } else { - echo '<a class="button" href="?id=' . $_GET['id'] . '&edit=1" >edit</a>'; - } - } - if ($app->session() >= $app::EDITOR) { - echo '<a class="button" href="?aff=media" >Media</a>'; - echo '<a class="button" href="?aff=record" >Record</a>'; - if ($app->session() >= $app::ADMIN) { - echo '<a class="button" href="?aff=admin" >Admin</a>'; - } - } - - - - - ?> - </div> - </nav> - <?php - - } - - // ____________________________________________________ M E D ________________________________________________ - - - public function addmedia($app) - { - if ($app->session() >= $app::EDITOR) { - - ?> - <details close> - <summary>Add Media</summary> - <form action="./" method="post" enctype="multipart/form-data"> - <input type="hidden" name="action" value="addmedia"> - <input type="file" accept="*" name="media" required> - <input type="text" name="id" id="" placeholder="nom du fichier" required> - <input type="submit" value="envoi"> - </form> - </details> - <?php - - } - } - - public function medialist(array $getlistermedia, $dir) - { - ?> - <details open> - <summary>Media List</summary> - - <form action="" method="post"> - - <table id=mediatable> - <tr><th>x</th><th>Name</th><th>extension</th><th>width</th><th>height</th><th>size</th><th>code</th><th>thumbnail</th></tr> - <?php - - - foreach ($getlistermedia as $item) { - $filepath = $dir . $item->id() . '.' . $item->extension(); - echo '<tr>'; - echo '<td><input type="checkbox" name="id[]" value=' . $item->id() . ' id="' . $item->id() . '"></td>'; - echo '<td><label for="' . $item->id() . '">' . $item->id() . '</label></td>'; - echo '<td>' . $item->extension() . '</td>'; - echo '<td>' . $item->width() . '</td>'; - echo '<td>' . $item->height() . '</td>'; - echo '<td>' . readablesize($item->size()) . '</td>'; - if ($item->type() == 'image') { - echo '<td><input type="text" value=" . '.' . $item->extension() . ')"></td>'; - echo '<td class="tooltip">👁<span class="infobulle"><a href="' . $filepath . '" target="_blank" ><img class="thumbnail" src="' . $filepath . '" alt="' . $item->id() . '"></a></span></td>'; - } elseif ($item->type() == 'sound') { - echo '<td><input type="text" value="[' . $item->id() . '](' . $filepath . ')"></td>'; - echo '<td><a href="' . $filepath . '" target="_blank" >♪</a></td>'; - } else { - echo '<td><input type="text" value="[' . $item->id() . '](' . $filepath . ')"></td>'; - echo '<td><a href="' . $filepath . '" target="_blank" >∞</a></td>'; - } - echo '</tr>'; - echo ''; - - } - - - ?> - - - </table> - - <select name="action" id=""> - <option value="">compress /2</option> - <option value="">downscale /2</option> - <option value="">upscale *2</option> - </select> - <input type="submit" value="edit"> - <input type="submit" value="delete"> - </form> - </div> - - </details> - - - <?php - - } - - - //______________________________________________________ R E C _________________________________________________ - - - public function recordlist(App $app, $dir = "../ACRRecordings/") - { - echo '<details open>'; - echo '<summary>Media List</summary>'; - - echo '<article class="gest">'; - - echo '<form action="" method="post">'; - - echo '<ul>'; - - foreach ($app->getlisterrecord($dir) as $item) { - echo '<li>'; - - ?> - <input type="checkbox" id="<?= $item->id() ?>" name="<?= $item->id() ?>" value="1"> - <label for="<?= $item->id() ?>"><?= $item->id() ?></label> - <input type="hidden" name="id" value="<?= $item->id() ?>"> - - <?php - - $filepathurl = $dir . urlencode($item->id()) . '.' . $item->extension(); - - echo '<br/>'; - var_dump($item->size()); - var_dump(intval($item->size())); - echo 'filesize = ' . readablesize(intval($item->size())); - echo '<br/>'; - echo 'extension = ' . $item->extension(); - echo '<br/>'; - - ?> - - <audio controls> - <source src="<?= $filepathurl ?>" type="audio/mpeg"> - </audio> - - - - <?php - - - - - echo '</li>'; - } - - echo '</ul>'; - - ?> - <select name="action" id=""> - <option value="">compress /2</option> - <option value="">downscale /2</option> - <option value="">upscale *2</option> - </select> - <input type="submit" value="edit"> - <input type="submit" value="delete"> - </form> - </div> - - - <?php - - - echo '</article>'; - echo '</details>'; - - - } - - - //______________________________________________________ A D M _________________________________________________ - - - - public function admincss(Config $config, $app) - { - ?> - <article> - <h2>CSS</h2> - - <p>CSS file :</p> - - <p><code> <?= $app::GLOBAL_CSS_DIR ?></code></p> - - <?php - $cssfile = $app::GLOBAL_CSS_DIR; - if (is_file($cssfile)) { - $cssread = file_get_contents($cssfile); - echo '<details>'; - echo '<summary>Edit current CSS</summary>'; - echo '<form action="./" method="post">'; - echo '<textarea name="editcss" id="cssarea">' . $cssread . '</textarea>'; - echo '<input type="hidden" name="action" value="editcss">'; - echo '<input type="submit" value="edit">'; - echo '</form>'; - echo '</details>'; - } - - ?> - - </article> - <?php - - } - - public function admindb($config) - { - ?> - - <article> - - - <h2>Database</h2> - - <details> - <summary>Database credentials</summary> - - <p>Fill this sections with the database settings you want to connect to</p> - - <form action="./" method="post"> - <input type="hidden" name="action" value="editconfig"> - <label for="host">Host</label> - <input title="host" type="text" name="host" id="host" value="<?= $config->host() ?>"> - <label for="dbname">DataBase name</label> - <input title="dbname" type="text" name="dbname" id="dbname" value="<?= $config->dbname() ?>"> - <label for="user">User name</label> - <input title="user" type="text" name="user" id="user" value="<?= $config->user() ?>"> - <label for="password">Password</label> - <input title="password" type="text" name="password" id="password" value="<?= $config->password() ?>"> - <input type="submit" value="edit" id=""> - </form> - - </details> - - - </article> - - <?php - - } - - public function adminpassword(Config $config) - { - ?> - <article> - - <h2>Passwords</h2> - - <details> - <summary>Admin</summary> - - <p>Edit your own admin password. You can find it in the config.w.json file, in the root of your website folder.</p> - - <form action="./" method="post"> - <input type="hidden" name="action" value="editconfig"> - <label for="admin">Administrator password (10)</label> - <input title="admin password" type="password" name="admin" id="admin" value="<?= $config->admin() ?>" > - <input type="submit" value="edit" id=""> - </form> - - </details> - <details> - <summary>Others</summary> - - <p>Use this section to set all the others users passwords. They cant access this page, so they cant change it by themselves.</p> - - <form action="./" method="post"> - <input type="hidden" name="action" value="editconfig"> - <label for="editor">Editor password (3)</label> - <input title="editor" type="text" name="editor" id="editor" value="<?= $config->editor() ?>"> - <label for="invite">Invite password (2)</label> - <input title="invite" type="text" name="invite" id="invite" value="<?= $config->invite() ?>" > - <label for="read">Reader password (1)</label> - <input title="read" type="text" name="read" id="read" value="<?= $config->read() ?>"> - <input type="submit" value="edit" id=""> - </form> - - </details> - </article> - - - - - <?php - - } - - public function admintable(Config $config, string $status, array $arttables) - { - ?> - - <article> - - <h2>Table</h2> - - - - <p>Database status : <strong><?= $status ?></strong></p> - - - <p>Current Table : <strong><?= $config->arttable(); ?></strong></p> - <details> - <summary>Select Table</summary> - <p>The table is where all your articles are stored, select the one you want to use.</p> - - <form action="./" method="post"> - <select name="arttable" required> - - <?php - foreach ($arttables as $arttable) { - if ($arttable == $config->arttable()) { - echo '<option value="' . $arttable . '" " selected >' . $arttable . '</option>'; - } else { - echo '<option value="' . $arttable . '">' . $arttable . '</option>'; - } - } - ?> - </select> - <input type="hidden" name="action" value="editconfig"> - <input type="submit" value="choose"> - </form> - - </details> - - <details> - <summary>Add table</summary> - - <p>Create new table in your database. You need at least one to use W_cms</p> - - <form action="./" method="post"> - <input type="hidden" name="actiondb" value="addtable"> - <input type="text" name="tablename" placeholder="table name" maxlength="30" required> - <input type="submit" value="create"> - </form> - - </details> - - <details> - <summary>Duplicate Table</summary> - <p>If you want to save versions of your work.</p> - - <form action="./" method="post"> - <label for="arttable">Select the table you want to copy.</label> - <select name="arttable" id="arttable" required> - - <?php - foreach ($arttables as $arttable) { - if ($arttable == $config->arttable()) { - echo '<option value="' . $arttable . '" " selected >' . $arttable . '</option>'; - } else { - echo '<option value="' . $arttable . '">' . $arttable . '</option>'; - } - } - ?> - </select> - <label for="tablename">Choose a name for the copy</label> - <input type="text" name="tablename" id="tablename" required> - <input type="hidden" name="actiondb" value="duplicatetable"> - <input type="submit" value="Duplicate"> - </form> - - </details> - - </article> - - <?php - - } - - public function admindisplay($color4) - { - ?> - <article> - <h2>Display</h2> - <details> - <summary>Update favicon</summary> - <form action="./" method="post" enctype="multipart/form-data"> - <input type="file" name="favicon" id="favicon"> - <input type="submit" value="update"> - </form> - </details> - <details> - <summary>Change desktop background color</summary> - <form action="./" method="post"> - <label for="color4">Background color</label> - <input type="color" name="color4" id="color4" value="<?= $color4 ?>"> - <input type="hidden" name="action" value="editconfig"> - <input type="submit" value="color my life"> - </form> - </details> - </article> - <?php - - } - - -} - - - -?>
\ No newline at end of file diff --git a/app/class/app4.php b/app/class/app4.php deleted file mode 100644 index b791846..0000000 --- a/app/class/app4.php +++ /dev/null @@ -1,657 +0,0 @@ -<?php -class App -{ - private $bdd; - private $session; - private $arttable; - - - const CONFIG_FILE = __DIR__ . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'w.config.json'; - const GLOBAL_CSS_DIR = '.' . DIRECTORY_SEPARATOR . 'css' . DIRECTORY_SEPARATOR . 'global' . DIRECTORY_SEPARATOR . 'global.css'; - const MEDIA_DIR = '.' . DIRECTORY_SEPARATOR . 'media' . DIRECTORY_SEPARATOR; - const MEDIA_EXTENSIONS = array('jpeg', 'jpg', 'JPG', 'png', 'gif', 'mp3', 'mp4', 'mov', 'wav', 'flac', 'pdf'); - const MEDIA_TYPES = ['image', 'video', 'sound', 'other']; - - - const ADMIN = 10; - const EDITOR = 3; - const INVITE = 2; - const READ = 1; - const FREE = 0; - - -// _____________________________________ C O N S T R U C T _________________________________ - - - - public function __construct() - { - $this->setsession($this::FREE); - } - - public function setbdd(Config $config) - { - $caught = true; - - try { - $this->bdd = new PDO('mysql:host=' . $config->host() . ';dbname=' . $config->dbname() . ';charset=utf8', $config->user(), $config->password(), array(PDO::ATTR_ERRMODE => PDO::ERRMODE_SILENT)); - //$this->bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); - } catch (PDOException $e) { - $caught = false; - echo '<h1>Error 500, database offline</h1>'; - if ($this->session() >= self::EDITOR) { - echo '<p>Error : ' . $e->getMessage() . '</p>'; - if ($this->session() == self::ADMIN) { - echo '<p>Go to the <a href="?aff=admin">Admin Panel</a> to edit your database credentials</p>'; - } else { - echo '<p>Logout and and come back with an <strong>admin password</strong> to edit the database connexions settings.</p>'; - } - } else { - echo '<p><a href=".">Homepage for admin login</a> (connect on the top right side)</p>'; - } - exit; - } - - return $caught; - - } - - public function settable(Config $config) - { - if (!empty($config->arttable())) { - $this->arttable = $config->arttable(); - } else { - echo '<h1>Table Error</h1>'; - - if ($this->session() >= self::EDITOR) { - if ($this->session() == self::ADMIN) { - echo '<p>Go to the <a href="?aff=admin">Admin Panel</a> to select or add an Article table</p>'; - } else { - echo '<p>Logout and and come back with an <strong>admin password</strong> to edit table settings.</p>'; - } - } else { - echo '<p><a href=".">Homepage for admin login</a> (connect on the top right side)</p>'; - } - $caught = false; - exit; - } - } - - public function bddinit(Config $config) - { - $test = $this->setbdd($config); - if ($test) { - $this->settable($config); - } - } - - -// _________________________________________ C O N F I G ____________________________________ - - public function readconfig() - { - if (file_exists(self::CONFIG_FILE)) { - $current = file_get_contents(self::CONFIG_FILE); - $donnees = json_decode($current, true); - return new Config($donnees); - } else { - return 0; - } - - } - - public function createconfig(array $donnees) - { - return new Config($donnees); - } - - - public function savejson(string $json) - { - file_put_contents(self::CONFIG_FILE, $json); - } - - - - - - -// ___________________________________________ A R T ____________________________________ - - - public function add(Art2 $art) - { - - if ($this->exist($art->id())) { - echo '<span class="alert">idalreadyexist</span>'; - } else { - - var_dump($art); - - $now = new DateTimeImmutable(null, timezone_open("Europe/Paris")); - - $request = 'INSERT INTO ' . $this->arttable . '(id, title, description, tag, date, datecreation, datemodif, daterender, css, quickcss, javascript, html, header, section, nav, aside, footer, render, secure, invitepassword, interface, linkfrom, template, affcount, editcount) - VALUES(:id, :title, :description, :tag, :date, :datecreation, :datemodif, :daterender, :css, :quickcss, :javascript, :html, :header, :section, :nav, :aside, :footer, :render, :secure, :invitepassword, :interface, :linkfrom, :template, :affcount, :editcount)'; - - $q = $this->bdd->prepare($request); - - $q->bindValue(':id', $art->id()); - $q->bindValue(':title', $art->title()); - $q->bindValue(':description', $art->description()); - $q->bindValue(':tag', $art->tag('string')); - $q->bindValue(':date', $now->format('Y-m-d H:i:s')); - $q->bindValue(':datecreation', $now->format('Y-m-d H:i:s')); - $q->bindValue(':datemodif', $now->format('Y-m-d H:i:s')); - $q->bindValue(':daterender', $now->format('Y-m-d H:i:s')); - $q->bindValue(':css', $art->css()); - $q->bindValue(':quickcss', $art->quickcss('json')); - $q->bindValue(':javascript', $art->javascript()); - $q->bindValue(':html', $art->html()); - $q->bindValue(':header', $art->header()); - $q->bindValue(':section', $art->md()); - $q->bindValue(':nav', $art->nav()); - $q->bindValue(':aside', $art->aside()); - $q->bindValue(':footer', $art->footer()); - $q->bindValue(':render', $art->render()); - $q->bindValue(':secure', $art->secure()); - $q->bindValue(':invitepassword', $art->invitepassword()); - $q->bindValue(':interface', $art->interface()); - $q->bindValue(':linkfrom', $art->linkfrom('json')); - $q->bindValue(':template', $art->template('json')); - $q->bindValue(':affcount', $art->affcount()); - $q->bindValue(':editcount', $art->editcount()); - - $q->execute(); - } - } - - public function delete(Art2 $art) - { - $req = $this->bdd->prepare('DELETE FROM ' . $this->arttable . ' WHERE id = :id '); - $req->execute(array('id' => $art->id())); - $req->closeCursor(); - } - - public function get($id) - { - $req = $this->bdd->prepare('SELECT * FROM ' . $this->arttable . ' WHERE id = :id '); - $req->execute(array('id' => $id)); - $donnees = $req->fetch(PDO::FETCH_ASSOC); - - return new Art2($donnees); - - $req->closeCursor(); - - } - - - - - - public function update(Art2 $art) - { - $now = new DateTimeImmutable(null, timezone_open("Europe/Paris")); - - //$request = 'UPDATE ' . $this->arttable . '(id, title, description, tag, date, datecreation, datemodif, daterender, css, quickcss, javascript, html, header, section, nav, aside, footer, render, secure, invitepassword, interface, linkfrom, template, affcount, editcount) VALUES(:id, :title, :description, :tag, :date, :datecreation, :datemodif, :daterender, :css, :quickcss, :javascript, :html, :header, :section, :nav, :aside, :footer, :render, :secure, :invitepassword, :interface, :linkfrom, :template, :affcount, :editcount) WHERE id = :id'; - - $request = 'UPDATE ' . $this->arttable . ' SET id = :id, title = :title, description = :description, tag = :tag, date = :date, datecreation = :datecreation, datemodif = :datemodif, daterender = :daterender, css = :css, quickcss = :quickcss, javascript = :javascript, html = :html, header = :header, section = :section, nav = :nav, aside = :aside, footer = :footer, render = :footer, secure = :secure, invitepassword = :invitepassword, interface = :interface, linkfrom = :linkfrom, template = :template, affcount = :affcount, editcount = :editcount WHERE id = :id'; - - $q = $this->bdd->prepare($request); - - $q->bindValue(':id', $art->id()); - $q->bindValue(':title', $art->title()); - $q->bindValue(':description', $art->description()); - $q->bindValue(':tag', $art->tag('string')); - $q->bindValue(':date', $now->format('Y-m-d H:i:s')); - $q->bindValue(':datecreation', $now->format('Y-m-d H:i:s')); - $q->bindValue(':datemodif', $now->format('Y-m-d H:i:s')); - $q->bindValue(':daterender', $now->format('Y-m-d H:i:s')); - $q->bindValue(':css', $art->css()); - $q->bindValue(':quickcss', $art->quickcss('json')); - $q->bindValue(':javascript', $art->javascript()); - $q->bindValue(':html', $art->html()); - $q->bindValue(':header', $art->header()); - $q->bindValue(':section', $art->md()); - $q->bindValue(':nav', $art->nav()); - $q->bindValue(':aside', $art->aside()); - $q->bindValue(':footer', $art->footer()); - $q->bindValue(':render', $art->render()); - $q->bindValue(':secure', $art->secure()); - $q->bindValue(':invitepassword', $art->invitepassword()); - $q->bindValue(':interface', $art->interface()); - $q->bindValue(':linkfrom', $art->linkfrom('json')); - $q->bindValue(':template', $art->template('json')); - $q->bindValue(':affcount', $art->affcount()); - $q->bindValue(':editcount', $art->editcount()); - - $q->execute(); - } - - public function exist($id) - { - $req = $this->bdd->prepare(' SELECT COUNT(*) FROM ' . $this->arttable . ' WHERE id = :id '); - $req->execute(array('id' => $id)); - $donnees = $req->fetch(PDO::FETCH_ASSOC); - - return (bool)$donnees['COUNT(*)']; - } - - - - - - //____________________________________________ L S T ______________________________ - - - - public function getlister(array $selection = ['id'], array $opt = []) - { - // give an array using SELECTION columns and sort and desc OPTIONS - - $default = ['tri' => 'id', 'desc' => 'DESC']; - $opt = array_update($default, $opt); - - $list = []; - $option = ['datecreation', 'title', 'id', 'description', 'datemodif', 'tag', 'secure']; - if (is_array($selection) && is_string($opt['tri']) && strlen($opt['tri']) < 16 && is_string($opt['desc']) && strlen($opt['desc']) < 5 && in_array($opt['tri'], $option)) { - - $selection = implode(", ", $selection); - - $select = 'SELECT ' . $selection . ' FROM ' . $this->arttable . ' ORDER BY ' . $opt['tri'] . ' ' . $opt['desc']; - $req = $this->bdd->query($select); - while ($donnees = $req->fetch(PDO::FETCH_ASSOC)) { - $list[] = new Art2($donnees); - } - return $list; - } - } - - - - - - - public function getlisteropt(Opt $opt) - { - - $artlist = []; - - $select = 'SELECT ' . $opt->col('string') . ' FROM ' . $this->arttable; - $req = $this->bdd->query($select); - while ($donnees = $req->fetch(PDO::FETCH_ASSOC)) { - $artlist[] = new Art2($donnees); - } - return $artlist; - - } - - public function listcalclinkfrom(&$artlist) - { - foreach ($artlist as $art) { - $art->calclinkto($artlist); - } - } - - public function artcompare($art1, $art2, $method = 'id', $order = 1) - { - $result = ($art1->$method('sort') <=> $art2->$method('sort')); - return $result * $order; - - } - - public function buildsorter($sortby, $order) - { - return function ($art1, $art2) use ($sortby, $order) { - $result = $this->artcompare($art1, $art2, $sortby, $order); - return $result; - }; - } - - - - public function artlistsort(&$artlist, $sortby, $order = 1) - { - return usort($artlist, $this->buildsorter($sortby, $order)); - } - - - - - - - public function filtertagfilter(array $artlist, array $tagchecked, $tagcompare = 'OR') - { - - $filteredlist = []; - foreach ($artlist as $art) { - if (empty($tagchecked)) { - $filteredlist[] = $art->id(); - } else { - $inter = (array_intersect($art->tag('array'), $tagchecked)); - if ($tagcompare == 'OR') { - if (!empty($inter)) { - $filteredlist[] = $art->id(); - } - } elseif ($tagcompare == 'AND') { - if (!array_diff($tagchecked, $art->tag('array'))) { - $filteredlist[] = $art->id(); - } - } - } - } - return $filteredlist; - } - - public function filtersecure(array $artlist, $secure) - { - $filteredlist = []; - foreach ($artlist as $art) { - if ($art->secure() == intval($secure)) { - $filteredlist[] = $art->id(); - } elseif (intval($secure) >= 4) { - $filteredlist[] = $art->id(); - } - } - return $filteredlist; - } - - - public function lister() - { - $req = $this->bdd->query(' SELECT * FROM ' . $this->arttable . ' ORDER BY id '); - $donnees = $req->fetchAll(PDO::FETCH_ASSOC); - $req->closeCursor(); - return $donnees; - - } - - public function tag(array $artlist, $tagchecked) - { - $artcheckedlist = []; - foreach ($artlist as $art) { - if (in_array($tagchecked, $art->tag('array'))) { - $artcheckedlist[] = $art; - } - } - return $artcheckedlist; - } - - public function taglist(array $artlist, array $tagcheckedlist) - { - $taglist = []; - foreach ($tagcheckedlist as $tag) { - $taglist[$tag] = $this->tag($artlist, $tag); - } - return $taglist; - } - - public function count() - { - return $this->bdd->query(' SELECT COUNT(*) FROM ' . $this->arttable . ' ')->fetchColumn(); - } - - - - // __________________________________________ T A B L E ________________________________________________________ - - - public function tableexist($dbname, $tablename) - { - - $req = $this->bdd->prepare('SELECT COUNT(*) - FROM information_schema.tables - WHERE table_schema = :dbname AND - table_name like :tablename'); - $req->execute(array( - 'dbname' => $dbname, - 'tablename' => $tablename - )); - $donnees = $req->fetch(PDO::FETCH_ASSOC); - $req->closeCursor(); - $exist = intval($donnees['COUNT(*)']); - return $exist; - - - - - } - - public function tablelist($dbname) - { - $request = 'SHOW TABLES IN ' . $dbname; - $req = $this->bdd->query($request); - $donnees = $req->fetchAll(PDO::FETCH_ASSOC); - $req->closeCursor(); - - $arttables = []; - foreach ($donnees as $table) { - $arttables[] = $table['Tables_in_' . $dbname]; - } - return $arttables; - - - } - - - - - - public function tableduplicate($dbname, $arttable, $tablename) - { - $arttable = strip_tags($arttable); - $tablename = str_clean($tablename); - if ($this->tableexist($dbname, $arttable) && !$this->tableexist($dbname, $tablename)) { - $duplicate = " CREATE TABLE `$tablename` LIKE `$arttable`;"; - $alter = "ALTER TABLE `$tablename` ADD PRIMARY KEY (`id`);"; - $insert = "INSERT `$tablename` SELECT * FROM `$arttable`;"; - - - $req = $this->bdd->query($duplicate . $alter . $insert); - - return 'tableduplicated'; - } else { - return 'tablealreadyexist'; - } - } - - - - -// __________________________________________ M E D ________________________________________________________ - - public function addmedia(array $file, $maxsize = 2 ** 24, $id) - { - $message = 'runing'; - $id = strtolower(strip_tags($id)); - $id = str_replace(' ', '_', $id); - if (isset($file) and $file['media']['error'] == 0 and $file['media']['size'] < $maxsize) { - $infosfichier = pathinfo($file['media']['name']); - $extension_upload = $infosfichier['extension']; - $extensions_autorisees = $this::MEDIA_EXTENSIONS; - if (in_array($extension_upload, $extensions_autorisees)) { - if (!file_exists($this::MEDIA_DIR . $id . '.' . $extension_upload)) { - - $extension_upload = strtolower($extension_upload); - $uploadok = move_uploaded_file($file['media']['tmp_name'], $this::MEDIA_DIR . $id . '.' . $extension_upload); - if ($uploadok) { - $message = 'uploadok'; - } else { - $message = 'uploaderror'; - } - } else { - $message = 'filealreadyexist'; - - } - } - } else { - $message = 'filetoobig'; - - } - - return $message; - } - - - public function getmedia($entry, $dir) - { - $fileinfo = pathinfo($entry); - - $filepath = $fileinfo['dirname'] . '.' . $fileinfo['extension']; - - $donnees = array( - 'id' => str_replace('.' . $fileinfo['extension'], '', $fileinfo['filename']), - 'path' => $dir, - 'extension' => $fileinfo['extension'] - ); - - - - return new Media($donnees); - - } - - public function getlistermedia($dir, $type = "all") - { - if ($handle = opendir($dir)) { - $list = []; - while (false !== ($entry = readdir($handle))) { - if ($entry != "." && $entry != "..") { - - $media = $this->getmedia($entry, $dir); - - - $media->analyse(); - - if (in_array($type, self::MEDIA_TYPES)) { - if ($media->type() == $type) { - $list[] = $media; - } - } else { - $list[] = $media; - } - - - } - } - return $list; - } - - return $list; - - } - - - - - //_________________________________________________________ R E C ________________________________________________________ - - - public function getlisterrecord($dir) - { - if ($handle = opendir($dir)) { - $list = []; - while (false !== ($entry = readdir($handle))) { - if ($entry != "." && $entry != "..") { - $fileinfo = pathinfo($entry); - - $filepath = $dir . $fileinfo['filename'] . '.' . $fileinfo['extension']; - - list($width, $height, $type, $attr) = getimagesize($filepath); - $filesize = filesize($filepath); - - $donnees = array( - 'id' => str_replace('.' . $fileinfo['extension'], '', $fileinfo['filename']), - 'path' => $fileinfo['dirname'], - 'extension' => $fileinfo['extension'], - 'size' => $filesize - ); - - $list[] = new Record($donnees); - - } - } - } - - return $list; - - - - } - - - - - // ________________________________________________________ M A P ________________________________________________________ - - - public function map(array $getlister, $lb = PHP_EOL) - { - - $map = ""; - $link = ""; - $style = ""; - foreach ($getlister as $item) { - if($item->secure() == 2) { - $style = $style . $lb . $item->id() . '{' . $item->title() . '}'; - } elseif ($item->secure() == 1) { - $style = $style . $lb . $item->id() . '(' . $item->title() . ')'; - - } else { - $style = $style . $lb . $item->id() . '((' . $item->title() . '))'; - } - foreach ($item->linkfrom('array') as $linkfrom) { - $map = $map . $lb . $item->id() . ' --> ' . $linkfrom; - $link = $link . $lb . 'click ' . $linkfrom . ' "./?id=' . $linkfrom . '"'; - - } - $link = $link . $lb . 'click ' . $item->id() . ' "./?id=' . $item->id() . '"'; - } - return $map . $link . $style; - - } - - - - - - //_________________________________________________________ S E S ________________________________________________________ - - public function login($pass, $config) - { - if (strip_tags($pass) == $config->admin()) { - return $level = self::ADMIN; - } elseif (strip_tags($pass) == $config->read()) { - return $level = self::READ; - } elseif (strip_tags($pass) == $config->editor()) { - return $level = self::EDITOR; - } elseif (strip_tags($pass) == $config->invite()) { - return $level = self::INVITE; - } - } - - public function logout() - { - return $level = 0; - } - - // ________________________________________________________ S E T ___________________________________________________ - - - public function setsession($session) - { - $this->session = $session; - } - - - - - //_________________________________________________________ G E T ________________________________________________________ - - public function session() - { - return $this->session; - } - - -} -?>
\ No newline at end of file diff --git a/app/class/application.php b/app/class/application.php index 8e50c19..4926a1b 100644 --- a/app/class/application.php +++ b/app/class/application.php @@ -50,6 +50,11 @@ class Application { ?> <h1>Configuration</h1> + + <h3>Version :</h3> + + <p><?= getversion() ?></p> + <form action="" method="post"> <div> <h2> diff --git a/app/class/config.php b/app/class/config.php index 36a5116..d6164ca 100644 --- a/app/class/config.php +++ b/app/class/config.php @@ -19,9 +19,7 @@ abstract class Config protected static $defaultart = ''; protected static $defaultfavicon = ''; protected static $showeditmenu = true; - protected static $editsymbol = 'pen'; - protected static $version = ''; - + protected static $editsymbol = 'pen'; diff --git a/app/class/controller.php b/app/class/controller.php index b0681bb..956d3b5 100644 --- a/app/class/controller.php +++ b/app/class/controller.php @@ -5,6 +5,9 @@ class Controller protected $user; protected $router; + /** + * @var Modeluser + */ protected $usermanager; protected $plates; diff --git a/app/class/controllermedia.php b/app/class/controllermedia.php index 4421f65..91f5a03 100644 --- a/app/class/controllermedia.php +++ b/app/class/controllermedia.php @@ -29,12 +29,17 @@ class Controllermedia extends Controller $dir = rtrim($_GET['path'] ?? Model::MEDIA_DIR, DIRECTORY_SEPARATOR); - $medialist = $this->mediamanager->getlistermedia($dir . DIRECTORY_SEPARATOR); - $faviconlist = $this->mediamanager->getlistermedia(Model::FAVICON_DIR); - - $dirlist = $this->mediamanager->listdir(Model::MEDIA_DIR); + if(is_dir($dir)) { + $medialist = $this->mediamanager->getlistermedia($dir . DIRECTORY_SEPARATOR); + $faviconlist = $this->mediamanager->getlistermedia(Model::FAVICON_DIR); + + $dirlist = $this->mediamanager->listdir(Model::MEDIA_DIR); + + $this->showtemplate('media', ['medialist' => $medialist, 'faviconlist' => $faviconlist, 'dirlist' => $dirlist, 'dir' => $dir]); + } else { + $this->routedirect('media'); + } - $this->showtemplate('media', ['medialist' => $medialist, 'faviconlist' => $faviconlist, 'dirlist' => $dirlist, 'dir' => $dir]); } else { $this->routedirect('home'); } @@ -57,7 +62,7 @@ class Controllermedia extends Controller { if ($this->user->iseditor()) { $dir = $_POST['dir'] ?? Model::MEDIA_DIR; - $name = $_POST['foldername'] ?? 'new folder'; + $name = idclean($_POST['foldername']) ?? 'new-folder'; $this->mediamanager->adddir($dir, $name); } $this->redirect($this->router->generate('media') . '?path=' . $dir . DIRECTORY_SEPARATOR . $name); diff --git a/app/class/modelmedia.php b/app/class/modelmedia.php index 6fbcece..42c826c 100644 --- a/app/class/modelmedia.php +++ b/app/class/modelmedia.php @@ -141,7 +141,6 @@ class Modelmedia extends Model public function adddir($dir, $name) { - $name = idclean($name); $newdir = $dir . DIRECTORY_SEPARATOR . $name; if(!is_dir($newdir)) { return mkdir($newdir); diff --git a/app/class/modeluser.php b/app/class/modeluser.php index 9dc2af1..a0f0966 100644 --- a/app/class/modeluser.php +++ b/app/class/modeluser.php @@ -1,66 +1,65 @@ <?php - class Modeluser extends Model { const ADMIN = 10; - const EDITOR = 3; - const INVITE = 2; - const READ = 1; + const EDITOR = 3; + const INVITE = 2; + const READ = 1; const FREE = 0; public function writesession(User $user) { - $_SESSION['user'] = ['level' => $user->level()]; + $_SESSION['user' . Config::basepath()] = ['level' => $user->level()]; } public function readsession() { $userdatas = []; - if(array_key_exists('user', $_SESSION)) { - $userdatas = $_SESSION['user']; + if (array_key_exists('user' . Config::basepath(), $_SESSION)) { + $userdatas = $_SESSION['user' . Config::basepath()]; } $user = new User($userdatas); return $user; } - + public function login($pass) - { + { $user = new User(['level' => $this->passlevel($pass)]); return $user; } - + public function passlevel($pass) { if (strip_tags($pass) == Config::admin()) { - return $level = self::ADMIN; - } elseif (strip_tags($pass) == Config::read()) { - return $level = self::READ; - } elseif (strip_tags($pass) == Config::editor()) { - return $level = self::EDITOR; - } elseif ($this->invitetest(strip_tags($pass))) { - return $level = self::INVITE; + return $level = self::ADMIN; + } elseif (strip_tags($pass) == Config::read()) { + return $level = self::READ; + } elseif (strip_tags($pass) == Config::editor()) { + return $level = self::EDITOR; + } elseif ($this->invitetest(strip_tags($pass))) { + return $level = self::INVITE; } else { - return $level = self::FREE; + return $level = self::FREE; } } public function invitetest($pass) { $invitepasslist = []; - if(in_array($pass, $invitepasslist)) { + if (in_array($pass, $invitepasslist)) { return true; } else { return false; } } - public function logout() - { + public function logout() + { $user = new User(['level' => self::FREE]); return $user; - } + } } diff --git a/app/class/w.article.php b/app/class/w.article.php deleted file mode 100644 index 6c504f8..0000000 --- a/app/class/w.article.php +++ /dev/null @@ -1,32 +0,0 @@ -<?php - -if ($app->exist($_GET['id'])) { - - $art = $app->get($_GET['id']); - - if (isset($_GET['edit']) and $_GET['edit'] == 1 and $app->session() >= $app::EDITOR) { - echo '<main class=edit>'; - $aff->edit($art, $app, $app->getlister(['id', 'title']), $config->fontsize(), $app->getlistermedia($app::MEDIA_DIR, 'image')); - $aff->aside($app); - echo '</main>'; - } else { - echo '<main class="lecture">'; - - - $art->autotaglistupdate($app->taglist($app->getlister(['id', 'title', 'description', 'tag']), $art->autotaglist())); - - - $aff->lecture($art, $app); - echo '</main>'; - - } -} else { - echo '<span class="alert">This article does not exist yet</span>'; - - if ($app->session() >= $app::EDITOR) { - echo '<form action="?id=' . $_GET['id'] . '&edit=1" method="post"><input type="hidden" name="action" value="new"><input type="submit" value="Create"></form>'; - } - -} - -?>
\ No newline at end of file diff --git a/app/class/w.home.php b/app/class/w.home.php deleted file mode 100644 index a23c60f..0000000 --- a/app/class/w.home.php +++ /dev/null @@ -1,85 +0,0 @@ -<?php - - -$aff->header(); - -echo '<main class="home">'; - - -if ($app->session() >= $app::EDITOR) { - - $app->bddinit($config); - - $opt = new Opt(Art2::classvarlist()); - $opt->setcol(['id', 'tag', 'linkfrom', 'contenu', 'description', 'title', 'datemodif', 'datecreation', 'secure']); - $table = $app->getlisteropt($opt); - $app->listcalclinkfrom($table); - $opt->settaglist($table); - $opt->submit(); - - - - - - - - - - - - $opt->setcol(['id', 'tag', 'linkfrom', 'contenu', 'description', 'title', 'datemodif', 'datecreation', 'secure', 'linkto']); - - - $aff->option($app, $opt); - - $filtertagfilter = $app->filtertagfilter($table, $opt->tagfilter(), $opt->tagcompare()); - $filtersecure = $app->filtersecure($table, $opt->secure()); - - $filter = array_intersect($filtertagfilter, $filtersecure); - $table2 = []; - $table2invert = []; - foreach ($table as $art) { - if (in_array($art->id(), $filter)) { - $table2[] = $art; - } else { - $table2invert[] = $art; - } - - - } - - if(!empty($opt->invert())) { - $table2 = $table2invert; - } - - $app->artlistsort($table2, $opt->sortby(), $opt->order()); - - - echo '<div id="flex">'; - - - $aff->home2table($app, $table2, $app->getlister()); - - - - - echo '<div id="map">'; - $aff->mapheader(); - if(isset($_GET['map'])) { - $aff->mermaid($app->map($table2)); - } - echo '</div>'; - - - - - - echo '</div>'; - -} - - - -echo '</main>'; - -?>
\ No newline at end of file diff --git a/app/class/w.menu.php b/app/class/w.menu.php deleted file mode 100644 index ecce576..0000000 --- a/app/class/w.menu.php +++ /dev/null @@ -1,56 +0,0 @@ -<?php - - -if ($app->session() >= $app::EDITOR) { - - if ($_GET['aff'] == 'admin' && $app->session() >= $app::ADMIN) { - echo '<main>'; - echo '<h1>Admin</h1>'; - - $aff->admincss($config, $app); - $aff->adminpassword($config); - $aff->admindb($config); - if ($app->setbdd($config)) { - $status = "OK"; - } else { - $status = "Not Connected"; - } - $aff->admintable($config, $status, $app->tablelist($config->dbname())); - $aff->admindisplay($config->color4()); - - echo '</main>'; - } elseif ($_GET['aff'] == 'media') { - echo '<h1>Media</h1>'; - echo '<main>'; - echo '<article>'; - - $aff->addmedia($app); - $aff->medialist($app->getlistermedia($app::MEDIA_DIR), $app::MEDIA_DIR); - - echo '</article>'; - echo '</main>'; - - } elseif ($_GET['aff'] == 'record') { - echo '<h1>Record</h1>'; - echo '<main>'; - - $aff->recordlist($app); - - echo '</main>'; - - } elseif ($_GET['aff'] == 'info') { - - - - } else { - - echo '<h1>Private</h1><p>You dont have the permission to access this page.</p>'; - - } - - -} else { - echo '<h1>Private</h1><p>You should be connected to access this page.</p>'; -} - -?>
\ No newline at end of file |