rhildred / editable
dev-master
2015-01-11 14:58 UTC
Requires
This package is not auto-updated.
Last update: 2025-01-04 18:49:05 UTC
README
composer installable module for editable markdown on a web page. There is a partial demo here. To use in a project, "require": {"rhildred/editable": "dev-master"}
in your composer.json file.
add an .htaccess in a folder named www in your repository:
AddHandler application/x-httpd-php .phtml
RewriteEngine On
RewriteCond %{REQUEST_URI}::$1 ^(.*?/)(.*)::\2$
RewriteRule ^(.*)$ - [E=BASE:%1]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME}.%{TIME_YEAR}.html -f
# Rewrite /foo/bar to /foo/bar.html
RewriteRule ^(.*)$ %{REQUEST_URI}.%{TIME_YEAR}.html [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME}.html -f
# Rewrite /foo/bar to /foo/bar.html
RewriteRule ^(.*)$ %{REQUEST_URI}.html [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME}.php -f
# Rewrite /foo/bar to /foo/bar.php
RewriteRule ^(.*)$ %{REQUEST_URI}.php [L]
RewriteCond %{REQUEST_FILENAME} -d
RewriteCond %{REQUEST_FILENAME}index.%{TIME_YEAR}.html -f
# Rewrite /foo/bar to have it compiled to a new php file
RewriteRule ^(.*)$ %{REQUEST_URI}index.%{TIME_YEAR}.html [L]
RewriteCond %{REQUEST_FILENAME} -d
RewriteCond %{REQUEST_FILENAME}index.html -f
# Rewrite /foo/bar to have it compiled to a new php file
RewriteRule ^(.*)$ %{REQUEST_URI}index.html [L]
RewriteCond %{REQUEST_FILENAME} -d
RewriteCond %{REQUEST_FILENAME}index.php -f
# Rewrite /foo/bar to have it compiled to a new php file
RewriteRule ^(.*)$ %{REQUEST_URI}index.php [L]
RewriteCond %{REQUEST_FILENAME} !-f
# Rewrite /foo/bar to have it compiled to a new php file
RewriteRule ^(.*)$ %{ENV:BASE}indexTransform.php/$1 [L]
Then you will also need some sort of routing. I added slim to my composer.json file:
"require":{
"rhildred/editable":"*",
"slim/slim": "*"
}
Also in the www folder I added:
<?php require_once(__DIR__ . '/../vendor/autoload.php');
$sScript = dirname(__FILE__) . $_SERVER['PATH_INFO'];
if(substr($sScript, -1) == "/") $sScript .= "index";
if (file_exists($sScript . ".phtml")){
\RHildred\Editable\Phtml::render($sScript);
}else{
session_start();
$sUrl = "http";
if(!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443)
{
$sUrl .= "s";
}
$sUrl .= "://" . $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"] . "/callback";
$app = new \Slim\Slim();
$app->get('/login', function () use ($app){
global $sUrl;
$oOauth2 = new \RHildred\Editable\Oauth2($sUrl);
$app->redirect($oOauth2->redirect());
});
$app->get('/login/callback', function () use ($app) {
global $sUrl;
$oOauth2 = new \RHildred\Editable\Oauth2($sUrl);
$rc= $oOauth2->handleCode($_GET["code"]);
$_SESSION["currentuser"] = $rc;
$app->redirect("../");
});
$app->get('/logout', function () {
unset($_SESSION["currentuser"]);
$rc = new stdClass();
$rc->result = "success";
echo json_encode($rc);
});
$app->get('/CurrentUser', function () {
if(!isset($_SESSION["currentuser"])) throw new Exception('no user logged in');
echo json_encode($_SESSION["currentuser"]);
});
$app->post('/ToMd/:sId', function($sId){
$sReferer = !empty($_SERVER['HTTP_REFERER'])? basename($_SERVER['HTTP_REFERER']):"index";
if($sReferer == "www" || $sReferer == "" || $sReferer == "salesucation.com") $sReferer = "index";
echo \RHildred\Editable\Markdown::save($sId, $_POST["sValue"], $sReferer);
});
$app->run();
}
When all of this is set up, you can use the javascript from the partial demo to enable web page composition and editing with Markdown.