Compare commits

...

63 Commits

Author SHA1 Message Date
7734de9fa4 Merge pull request 'Fix issues #25 and #26' (#27) from issue#26 into master
Reviewed-on: #27
2022-08-09 14:15:37 -04:00
470773721a Stop parsing if the author isn't found 2022-08-09 14:10:44 -04:00
5d7b4cc121 Add a size check before attempting to parse the author
The author file is now checked to insure it's non-zero before attempting
to parse it for the author who's byline will be displayed at the bottom
of the post.
2022-08-09 14:07:40 -04:00
efe61157e8 Merge pull request 'Cleanup header.php' (#22) from issue#10 into master
Reviewed-on: #22
2022-07-31 17:12:49 -04:00
5016fa8ce8 Cleanup header.php
Cleanup debugging code for issue #10
2022-07-31 17:10:41 -04:00
206f94f5db Fix variable being tested for empty file in PR #21 2022-07-27 22:11:36 -04:00
7ff2cf1d0f Resolve issue #9 (#21) 2022-07-27 20:17:34 -04:00
f80bc8dafa File permissions change, check for non-zero tags.csv for issue #9
The tags index.php file now checks for the tags.csv to be non-zero as
well as existing.
Updated the permission of the generated tags.csv file to allow the CMS
to updated it with out requiring root/sudo permissions.
2022-07-27 20:08:55 -04:00
32f7d23ee4 Merge pull request 'Merge upstream master' (#4) from 20xd6/simple_blog:master into master
Reviewed-on: manfromhuh/simple_blog#4
2022-07-27 13:02:23 -04:00
015c5ef6db Fix for issue #18
The page generation now checks for the size of $file_arr and only
generates a menu if the size os greater than 0.
2022-07-26 13:33:49 -04:00
4958a76f9a Remove old csv reading code. 2022-07-26 13:29:08 -04:00
b01c237d5d Merge pull request 'Update tags index to handle issue #9' (#20) from issue#9 into master
Reviewed-on: #20
2022-07-26 13:10:05 -04:00
dd3405137f Update tags index to handle issue # 9
Now checks for the file and either copies a backup or creates a blank
file.
2022-07-26 13:06:52 -04:00
25f1887590 Merge pull request 'issue #7' (#19) from issue#7 into master
Reviewed-on: #19
2022-07-26 11:28:32 -04:00
81629aa133 Remove deperacted CSS for issue #7
The style rules have been moved into the main styles.css
2022-07-26 11:25:03 -04:00
3e169d54ed Remove depracated PHP for issue #7 2022-07-26 11:22:18 -04:00
b7688ae2d4 Removed empty php file 2022-07-26 11:21:52 -04:00
dc66b2db0f Remove depracated JS files for issue #7
The functions in these files have been merged into the main JS file for
page formatting.
2022-07-26 11:20:33 -04:00
88b08fd1fc If not author is identified do nothing 2022-07-26 11:01:36 -04:00
d2861f1203 Merge pull request 'Merge with upstream' (#3) from 20xd6/simple_blog:master into master
Reviewed-on: manfromhuh/simple_blog#3
2022-07-26 10:42:54 -04:00
5e29d1e4d5 add_byline (#17) 2022-07-26 10:33:29 -04:00
2e1dc4a38a Update CSS to show the author pfp in a small circle 2022-07-26 10:18:10 -04:00
28a4f0021e Update article generation to include a author byline 2022-07-26 10:17:27 -04:00
ba25c81ca6 Update composer 2022-07-26 10:16:53 -04:00
ad07963e4b Add article tags 2022-07-17 18:06:22 -04:00
5cce4f0b0d Update the pfp size CSS
Add a pfp-small class and adjust the pfp size to 50px by 50px.
2022-07-17 18:01:55 -04:00
a0e3de1200 Update to use the new md_read.php 2022-07-17 17:55:56 -04:00
8ce95a06d9 Add article.php
The new location for text size buttons and other article specific elements.
2022-07-17 17:51:59 -04:00
fb1c649580 Update index.php to use the function
Also seperates the HTML used for just articles from the Markdown parsing.
2022-07-17 17:50:02 -04:00
3a2dc7651a Fix output 2022-07-17 17:42:39 -04:00
d719bcf101 Place Markdown parsing in a function 2022-07-17 17:27:08 -04:00
b4c852a3c1 Style the author pfp 2022-07-15 22:01:27 -04:00
849d5a25b6 Add author pfp to list 2022-07-15 21:47:26 -04:00
4d4ce6f0a5 Add author pfp 2022-07-15 21:24:36 -04:00
340997fa89 Add generic author index.php 2022-07-15 21:14:27 -04:00
4929ea5eb8 Remove formatting from directory list 2022-07-15 21:09:05 -04:00
1cf4ffface Add <a> tags to better format list. 2022-07-15 21:00:46 -04:00
17cf1d28f0 Update authors/index.php 2022-07-15 20:51:23 -04:00
f57ace3bad Add /blog/authors/ directory 2022-07-15 20:29:37 -04:00
1da2fe8358 Merge pull request 'Update to upstream master' (#2) from 20xd6/simple_blog:master into master
Reviewed-on: manfromhuh/simple_blog#2
2022-07-15 19:47:37 -04:00
00a2458977 Update error pages 2022-07-08 09:10:14 -04:00
8302028049 Update pages with changes to /common/
The building block PHP files have been moved.
2022-07-07 22:40:11 -04:00
b692b22935 Move PHP files to /common/php/ 2022-07-07 22:33:21 -04:00
01de94a893 Update 2022-07-07 22:24:46 -04:00
bedc11a4ce Move CSS files to /common/css/
Moved all CSS files to their own sub-directory and updated header.php to
reflect this change.
2022-07-06 15:26:18 -04:00
842ea4e411 Remove /common/prisim/ from repository 2022-07-06 15:25:01 -04:00
8b4b5dd31d Updated header.php with new page_format.js path 2022-07-06 15:24:09 -04:00
35cd14e0b0 Move JS files to /common/js/
To cleanup the code in /common/ all JavaScript files have been moved to
/common/js/
issue#2
2022-07-06 15:20:32 -04:00
d743fb297b Move Prism files to a properly spelled directory
Moved the Prism project files from /common/prisim/ to /common/prism/.
Updated the code in /common/page_format.js that loads these files.
2022-07-06 15:17:41 -04:00
87a07aaf02 Merge pull request 'Add documentation.' (#13) from manfromhuh/simple_blog:master into master
Reviewed-on: #13
2022-07-05 15:22:31 -04:00
f1b3eec9d8 Readd README.md to resolve merge confilict 2022-07-05 15:16:48 -04:00
91119d3575 Merge branch 'code_docs' 2022-07-05 15:13:44 -04:00
6b06c36b0b Merge pull request 'Update to upstream master' (#1) from 20xd6/simple_blog:master into master
Reviewed-on: manfromhuh/simple_blog#1
2022-07-05 15:10:54 -04:00
394e34b7b8 Update URL path 2022-07-05 15:01:32 -04:00
de3986efcb Add comments to page_menu.php 2022-07-05 14:45:16 -04:00
58f94c415d Add comments to index.php 2022-07-05 14:40:20 -04:00
4117b552f2 Add comments to header.php
This file needs it's Title() function cleaned up.
2022-07-05 14:36:54 -04:00
a00013d619 Add comments to h1_month.php 2022-07-05 14:33:18 -04:00
ef7056be35 Add comments to get_month_name.php 2022-07-05 14:32:11 -04:00
93514c0e1d Add comments to page_format.js 2022-07-05 14:29:43 -04:00
e1ac241f2a Add Completed README.md 2022-07-05 14:18:49 -04:00
a2ee59d2f3 Fix for issue#8
The array was being processed such that it would stop when it reached
the number of row not the number of coloums.
2022-07-05 10:56:02 -04:00
cfc878013d Test README.md 2022-07-02 12:48:30 -04:00
46 changed files with 1044 additions and 503 deletions

135
README.md
View File

@ -1 +1,136 @@
# simple_blog # simple_blog
simple_blog is a basic blogging platform. It is designed to be a straightforward way to publish articles written in Markdown and display them using a renderer written in PHP. There is no login page or any way to manage simple_blog from the web. All management is done via the command line. This can be done with a shell script or with the python based [simple_blog_cms](/git/20xd6/simple_blog_cms).
## Requirements
* Currently tested with PHP 7.4
* Some shell access is necessary.
* The recommend way is via ssh.
* I don't see a technical reason it can't work with a web manager like cPannel or Ajenti as long has you have the ability to upload files and manage files.
## Publishing
Publishing can be done manually or with a script that accomplishes the following tasks.
1. Create a directory under `/blog/by_year/$CURRENT_YEAR/$CURRENT_MONTH/`
* For a post in January of 2022 this would be `/blog/by_year/2022/01/`
* The directory should start with a numeral otherwise it will be sorted alphabetically
2. Place a file named `article.md` containing the MarkDown formatted text of the article in the directory created in the previous step
3. Copy or symlink `/common/index.php` into the directory created in step 1
4. Place a file named `tags` containing a comma separated list of tags for the article in the directory created in step 1
5. Add the article's relative path and title to `/by_tag/tags.csv` under the appropriate headings.
The recommended method is to use [simple_blog_cms](/git/20xd6/simple_blog_cms "simple_blog_cms")
## Article Tags
### Per-article List
A file named `tags` is placed in the directory for each article. It should contain a comma separated list of tags being applied to the article. This will be parsed and displayed by [`/common/md_read.php`](/git/20xd6/simple_blog/src/branch/master/common/md_read.php) at the bottom of the article.
### by_tags
This folder contains an index file that displays an article list generated by parsing the `tags.csv` file. A format example is displayed below.
| "PHP" | "JS" | "Religion" | "Catholic" |
| ----- | ---- | ---------- | ---------- |
| "/blog/by_year/2021/10/03_Forcing_Elements_to_reload/" | "/blog/by_year/2021/10/03_Forcing_Elements_to_reload/" |"/blog/by_year/2021/10/reproduction_of_Gainer_Bishop_Ronald_4-1-16/" | reproduction_of_Gainer_Bishop_Ronald_4-1-16/" |
| "Forcing page elements to reload" | "Forcing page elements to reload" | "Open Letter to Bishop Ronald Gainer" | "Open Letter to Bishop Ronald Gainer" |
| "/blog/by_year/2022/06/28_A_Test_Post/"| | |
| "A Test Post" | | |
## File Descriptions
### blog
Contains the blog articles. The articles are placed in subdirectories of `by_year` according to the year and month they were published.
```
├── by_year
│   ├── 2021
│   │   ├── 12
│   │   └── index.php -> /path/to/common/index.php
│   ├── 2022
│   │   ├── 01
│   │   ├── 02
│   │   └── index.php -> /path/to/common/index.php
│   └── index.php
└── index.php -> /path/to/common/index.php
```
### common
This directory contains the files and libraries used to render the site's pages.
#### Composer files
* composer.json
* composer.lock
* [/common/vendor]() - Stores the composer files and libraries managed via composer.
#### CSS
* [styles.css](/git/20xd6/simple_blog/src/branch/master/common/styles.css) - The main site CSS.
* [jmenu.css]() - Used to render the responsive menus.
* [print.css]() - Used to style printed pages.
* [gallery.css]() - Styles the floating
#### JS
* font_size.js
* [page_format.js]() - The main JS file used for formatting and adding extra functions to pages.
* gallery.js
#### PHP
* [footer.php]() - The common page footer. Contains copyright information and links to the license.
* [get_month_name.php]() - Translates a numeral month into the corresponding name. I.E. 01 into January.
* [h1_month.php]() - Adds the proper `<h1>` heading based on the location of the
* [header.php]() - The common page header.
* [index.php]() - The index file used for most of the pages on the site.
* [markdown.php]()
* [md_read.php]() - Renders Markdown files and adds
* [menu.php]() - Generates the blog menu items in the navigation menu.
* [modal.php]() - Adds the modal `<div>` for displaying the image pop out.
* [page_menu.php]() - Generates a menu from the files and directories where it's run from.
* [page_menu_table.php]()
* [path_menu.php]()
#### /common/error_pages/
* [/common/403.php]() - The 403 not allowed page.
* [/common/404.php]() - The 404 page.
* [/common/500.php]() - Displayed for all HTTP 500 errors
#### /common/imgs/
Images used site wide.
* [cursor.gif]() - Blinking cursor used on the front page.
* [icon-rss.png]() - RSS icon
#### /common/prisim
Files for the prism syntax highlighter.
### license
This directory contains all the licensing information for simple_blog. simple_blog is licensed under the GPLv2 but uses components that are licensed under the MIT Open Source license. These components are:
* [Jmenu](https://github.com/jamesjohnson280/JMenu)
* [Parsedown](https://github.com/erusev/parsedown)
* [Parsedown-extra](https://github.com/erusev/parsedown-extra)
#### index.php
Displays all of the reverent license and the components they apply to.
* simple_blog is licensed GPLv2. This cannot be changed.
* Default license for articles published. This is [Creative Commons Attribution 3.0 Unported License](http://creativecommons.org/licenses/by/3.0/) by default. This licensed can be changed however the site admin wishes.
* [Jmenu](https://github.com/jamesjohnson280/JMenu) is licensed MIT. This cannot be changed.
* [Parsedown](https://github.com/erusev/parsedown) is licensed MIT. This cannot be changed.
* [Parsedown-extra](https://github.com/erusev/parsedown-extra) is licensed MIT. This cannot be changed.
Copies of all these licenses can be found in the `/license/` directory.

67
blog/authors/index.php Normal file
View File

@ -0,0 +1,67 @@
<?php
include ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
?>
<h1>Authors</h1>
<nav id="body_nav" class="jmenu">
<div class="pmenu">
<ul><li><a href=/>Home</a></li></ul>
<?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/get_month_name.php');
//Removes the number used to keep articles in post order from the displayed title.
function remove_sorting_number($link_title){
$first_three = mb_substr($link_title, 0, 3,"UTF-8");
if ( preg_match( '/[0-9][0-9] /', $first_three) ){
$link_title = mb_substr($link_title,3);
}
return $link_title;
}
$dir = '.';
// Check if the directory exists
if (file_exists($dir) && is_dir($dir) ) {
// Get the files of the directory as an array
$scan_arr = scandir($dir);
$files_arr = array_diff($scan_arr, array('.','..','index.php','common','.htaccess') );
// echo "<pre>"; print_r( $files_arr ); echo "</pre>";
// Get each files of our directory with line break
foreach ($files_arr as $file) {
//Get the file path
$file_path = "./".$file;
// Get the file extension
$file_ext = pathinfo($file_path, PATHINFO_EXTENSION);
if ($file_ext == "") {
$file_array[] = $file;
}
}
if (sizeof($file_array) != 0){
foreach($file_array as $file) {//Renders the folder names as more readable titles.
$link_title = str_replace('_',' ',$file);//Remove undersores and replace them with spaces
$link_title = str_replace($_replace,'',$link_title);
if (file_exists($file."/pfp.png")){
$pfp_path = "$file/pfp.png";
echo("<ul><li><img src=\"$pfp_path\" class=\"pfp-small\" name=\"$file pfp\"><a href='$file'> $link_title </a></li></ul>\n");//Output the result.
} else {
echo("<ul><li><a href='$file'> $link_title </a></li></ul>\n");//Output the result.
}
}
} else {
echo "<ul><li><a>No Authors<a></li></ul>";
}
}
else {
echo "Directory does not exists";
}
echo("<ul><li><a href='..'>Back</a></li></ul>\n");
?>
</div><!--end of pmenu-->
</nav>
<br>
<?php
include ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?>

110
blog/by_tag/index.php Normal file → Executable file
View File

@ -1,68 +1,60 @@
<?php <?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
echo "<article><h1 id=\"page_title\">Posts by Tag</h1></article>"; echo "<article><h1 id=\"page_title\">Posts by Tag</h1></article>";
echo "<div id=\"search_inputs\"><input type=\"text\" id=\"tag_sort\" onkeyup=\"tag_search()\" placeholder=\"Search Tags...\" title=\"Type a tage to search\"><input id=\"search_toggle\" type=\"button\" value=\"Search Titles\" onclick=\"search_toggle()\"></div><!--End Div Search Inputs-->"; echo "<div id=\"search_inputs\"><input type=\"text\" id=\"tag_sort\" onkeyup=\"tag_search()\" placeholder=\"Search Tags...\" title=\"Type a tage to search\"><input id=\"search_toggle\" type=\"button\" value=\"Search Titles\" onclick=\"search_toggle()\"></div><!--End Div Search Inputs-->";
function read_tags($tags_file){
//if(file_exists("tags.csv")){ if (filesize($tags_file) == 0){
//echo "<ul id=\"tag_menu\">\n"; echo "<br/>\n<br/>";
//$csv = array_map('str_getcsv', file("tags.csv")); return;
//array_walk($csv, function(&$a) use ($csv) { }
//$a = array_combine($csv[0], $a); $tags_csv = array_map('str_getcsv', file('tags.csv'));
//}); $tags_rows = sizeof($tags_csv);
//array_shift($csv); # remove column header $tags_coloums = sizeof($tags_csv[0]);
//foreach ($csv as $row){ //echo "<pre>\n";
//$counter = 0; //print_r($tags_csv);
//foreach ($row as $item){ //echo $tags_coloums . "\n" . $tags_rows . "\n";
//$counter++; //echo "</pre>\n";
//if ($counter == 1){ echo "<ul id=\"tag_menu\">\n";
//echo "\t<li id=\"" . $item . "\">" . $item . " <a id=\"" . $item . "\"></a>\n"; $coloum_number = 0;
//} elseif ($counter % 2 == 0) { for ($row_number = 0; $row_number <= $tags_coloums; $row_number++){
//if ($item == ""){ //echo $row_number;
//break; $section_title = $tags_csv[0][$coloum_number];
//} else { echo "\t<li id=\"" . $section_title . "\"><b>" . $section_title . " </b>\n";
//echo "\t\t<ol><a href=\"" . $item . "\">"; for ($row = 1; $row < $tags_coloums; $row++){
//} //echo "rn: " . $row . "\ncn:" . $coloum_number ." ";
//} elseif ($counter % 2 != 0) { $tag_content = $tags_csv[$row][$coloum_number];
//echo $item . "</a></ol>\n"; if ($tag_content == ""){
//} break;
//} } else {
//echo "\t</li>\n"; if ($row % 2 != 0){
//} echo "\t\t<ol><a href=\"" . $tag_content . "\">";
//echo "</ul>\n"; } elseif ($row % 2 == 0){
//} echo $tag_content . "</a></ol>\n";
}
# Tags rewrite
$tags_csv = array_map('str_getcsv', file('tags.csv'));
$tags_rows = sizeof($tags_csv);
$tags_coloums = sizeof($tags_csv[0]);
//echo "<pre>\n";
//print_r($tags_csv);
//echo $tags_coloums . "\n" . $tags_rows . "\n";
//echo "</pre>\n";
echo "<ul id=\"tag_menu\">\n";
$coloum_number = 0;
for ($row_number = 0; $row_number < $tags_rows; $row_number++){
#echo $row_number;
$section_title = $tags_csv[0][$coloum_number];
echo "\t<li id=\"" . $section_title . "\"><b>" . $section_title . " </b>\n";
for ($row = 1; $row < $tags_coloums; $row++){
#echo "rn: " . $row_number . "\ncn:" . $coloum_number;
$tag_content = $tags_csv[$row][$coloum_number];
if ($tag_content == ""){
break;
} else {
if ($row % 2 != 0){
echo "\t\t<ol><a href=\"" . $tag_content . "\">";
} elseif ($row % 2 == 0){
echo $tag_content . "</a></ol>\n";
} }
} }
echo "\t</li>\n";
$coloum_number++;
} }
echo "\t</li>\n"; echo "</ul>\n";
$coloum_number++;
} }
echo "</ul>\n";
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');
# Tags rewrite
if (file_exists('tags.csv')){
read_tags('tags.csv');
} elseif( file_exists('tags.csv.bak') ){
if (copy('tags.csv.bak', './tags.csv')) {
read_tags('tags.csv');
}
}else {
$empty_csv = fopen("tags.csv", "w") or die("Cannot write new tags.csv file.");
fwrite($empty_csv, "");
fclose($empty_csv);
chmod('./tags.csv', 0666);
read_tags('tags.csv');
}
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?> ?>

18
common/authors/index.php Normal file
View File

@ -0,0 +1,18 @@
<?php
//The common file used to render pages on the blog.
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
//Looks for an article.md to see if the current directory is an article or not
//If it is not then it is a menu page.
echo "<article>";
if (file_exists('byline.md')){
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/md_read.php');
echo read_md('byline.md');
}
if (file_exists('author.md')){
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/md_read.php');
echo read_md('author.md');
}
echo "</article>";
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?>

View File

@ -1,6 +1,5 @@
{ {
"require": { "require": {
"erusev/parsedown": "^1.7",
"erusev/parsedown-extra": "^0.8.1" "erusev/parsedown-extra": "^0.8.1"
} }
} }

20
common/composer.lock generated
View File

@ -1,11 +1,10 @@
{ {
"_readme": [ "_readme": [
"This file locks the dependencies of your project to a known state", "This file locks the dependencies of your project to a known state",
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
"This file is @generated automatically" "This file is @generated automatically"
], ],
"hash": "aa5767a5b8fb16d5e73cc5639dd2604b", "content-hash": "ab175e79f029b7846e324d73005f0a67",
"content-hash": "0b5aa77427c5746d4d87e5e921804d34",
"packages": [ "packages": [
{ {
"name": "erusev/parsedown", "name": "erusev/parsedown",
@ -51,7 +50,11 @@
"markdown", "markdown",
"parser" "parser"
], ],
"time": "2019-12-30 22:54:17" "support": {
"issues": "https://github.com/erusev/parsedown/issues",
"source": "https://github.com/erusev/parsedown/tree/1.7.x"
},
"time": "2019-12-30T22:54:17+00:00"
}, },
{ {
"name": "erusev/parsedown-extra", "name": "erusev/parsedown-extra",
@ -98,7 +101,11 @@
"parsedown", "parsedown",
"parser" "parser"
], ],
"time": "2019-12-30 23:20:37" "support": {
"issues": "https://github.com/erusev/parsedown-extra/issues",
"source": "https://github.com/erusev/parsedown-extra/tree/0.8.x"
},
"time": "2019-12-30T23:20:37+00:00"
} }
], ],
"packages-dev": [], "packages-dev": [],
@ -108,5 +115,6 @@
"prefer-stable": false, "prefer-stable": false,
"prefer-lowest": false, "prefer-lowest": false,
"platform": [], "platform": [],
"platform-dev": [] "platform-dev": [],
"plugin-api-version": "2.0.0"
} }

View File

@ -125,6 +125,27 @@ img{
img.center_align{ img.center_align{
vertical-align:middle; vertical-align:middle;
} }
img.pfp {
vertical-align: middle;
width: 50px;
height: 50px;
border-radius: 25px;
border-style: solid;
border-width: 1px;
}
img.pfp-small {
vertical-align: middle;
width: 25px;
height: 25px;
border-radius: 25px;
border-style: solid;
border-width: 1px;
}
div.byline {
border-top: solid;
margin-left: 25%;
margin-right: 25%;
}
.top{ .top{
max-width: 100vw; max-width: 100vw;
float: left; float: left;
@ -322,6 +343,12 @@ img:hover {opacity: 0.7;}
margin-left: 5%; margin-left: 5%;
margin-right: 5%; margin-right: 5%;
} }
div.byline {
border-top: solid;
margin-left: 5%;
margin-right: 5%;
}
h1{ h1{
padding-left: 5%; padding-left: 5%;
} }

View File

@ -1,6 +1,6 @@
<?php <?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/menu.php');
?> ?>
<h1 align="center">Error 403</h1> <h1 align="center">Error 403</h1>
<p align="center"> <p align="center">
@ -11,4 +11,4 @@ include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php');
<br/> <br/>
You're not allowed here. Stop that.<br/> You're not allowed here. Stop that.<br/>
</p> </p>
<?php include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');?> <?php include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/footer.php');?>

View File

@ -1,6 +1,6 @@
<?php <?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/menu.php');
?> ?>
<h1 align="center">Error 404</h1> <h1 align="center">Error 404</h1>
<p align="center"> <p align="center">
@ -21,4 +21,4 @@ include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php');
</div> </div>
<br/> <br/>
<br/> <br/>
<?php include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');?> <?php include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/footer.php');?>

View File

@ -1,10 +1,10 @@
<?php <?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/menu.php');
?> ?>
<h1 align="center">Error 500</h1> <h1 align="center">Error 500</h1>
<p align="center"> <p align="center">
<br/> <br/>
We done made a boo boo...<br/> We done made a boo boo...<br/>
</p> </p>
<?php include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');?> <?php include_once ($_SERVER['DOCUMENT_ROOT'].'common/php/footer.php');?>

View File

@ -1 +0,0 @@

View File

@ -1,79 +0,0 @@
/* Style the Image Used to Trigger the Modal */
#myImg {
border-radius: 5px;
cursor: pointer;
transition: 0.3s;
}
img:hover {opacity: 0.7;}
/* The Modal (background) */
.modal_gal {
display: none; /* Hidden by default */
position: fixed; /* Stay in place */
z-index: 1; /* Sit on top */
padding-top: 100px; /* Location of the box */
left: 0;
top: 0;
width: 100%; /* Full width */
height: 100%; /* Full height */
overflow: auto; /* Enable scroll if needed */
background-color: rgb(0,0,0); /* Fallback color */
background-color: rgba(0,0,0,0.9); /* Black w/ opacity */
}
/* Modal Content (Image) */
.gallery_img {
margin: auto;
display: block;
width: 80%;
max-width: 700px;
}
/* Caption of Modal Image (Image Text) - Same Width as the Image */
#modal_img_caption {
margin: auto;
display: block;
width: 80%;
max-width: 700px;
text-align: center;
color: #ccc;
padding: 10px 0;
height: 150px;
}
/* Add Animation - Zoom in the Modal */
.gallery_img, #caption {
animation-name: zoom;
animation-duration: 0.6s;
}
@keyframes zoom {
from {transform:scale(0)}
to {transform:scale(1)}
}
/* The Close Button */
.close_modal {
position: absolute;
top: 15px;
right: 35px;
color: #00cc00;
font-size: 40px;
font-weight: bold;
transition: 0.3s;
}
.close_modal:hover,
.close_modal:focus {
color: #bbb;
text-decoration: none;
cursor: pointer;
}
/* 100% Image Width on Smaller Screens */
@media only screen and (max-width: 700px){
.gallery_img {
width: 100%;
}
}

View File

@ -1,32 +0,0 @@
var modalEle = document.querySelector(".modal_gal");
var modalImage = document.querySelector(".gallery_img");
Array.from(document.querySelectorAll(".img_thumb")).forEach(item => {
item.addEventListener("click", event => {
modalEle.style.display = "block";
modalImage.src = event.target.src;
});
});
document.querySelector(".close").addEventListener("click", () => {
modalEle.style.display = "none";
});
function image_modal(document){
// Get the modal
var modal = document.getElementById("modal_gallery");
// Get the image and insert it inside the modal - use its "alt" text as a caption
var img = document.getElementById("myImg");
var modalImg = document.getElementById("modal_img");
var captionText = document.getElementById("modal_img_caption");
img.onclick = function(){
modal.style.display = "block";
modalImg.src = this.src;
captionText.innerHTML = this.alt;
}
// Get the <span> element that closes the modal
var span = document.getElementsByClassName("close_modal")[0];
// When the user clicks on <span> (x), close the modal
span.onclick = function() {
modal.style.display = "none";
}
}

View File

@ -1,11 +0,0 @@
<?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php');
if (file_exists('article.md')){
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/md_read.php');
} else {
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/h1_month.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/page_menu.php');
}
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');
?>

View File

@ -1,25 +1,30 @@
//
function format_page(){//Set the title of the page based on the main header, <h1>, tag.le != '' )){ function format_page(){//Set the title of the page based on the main header, <h1>, tag.le != '' )){
if ( document.getElementsByTagName('h1').length !== 0){ if ( document.getElementsByTagName('h1').length !== 0){
document.title = document.getElementsByTagName('h1')[0].innerText; document.title = document.getElementsByTagName('h1')[0].innerText;
} }
//detect if the page contains code blocks to be highlighted and loads the prisim.js and prism.css files to accomplish this. //Detect if the page contains code blocks to be highlighted and loads the
//prisim.js and prism.css files if codeblocks are found.
code_tag = document.getElementsByTagName('code').length; code_tag = document.getElementsByTagName('code').length;
if ( code_tag !== 0 ){ if ( code_tag !== 0 ){
var script = document.createElement('script'); var script = document.createElement('script');
var style_sheet = document.createElement('link'); var style_sheet = document.createElement('link');
script.type = 'text/javascript'; script.type = 'text/javascript';
script.src = '/common/prisim/prism.js'; script.src = '/common/prism/prism.js';
style_sheet.type = 'text/css'; style_sheet.type = 'text/css';
style_sheet.href = '/common/prisim/prism.css'; style_sheet.href = '/common/prism/prism.css';
style_sheet.rel = 'stylesheet'; style_sheet.rel = 'stylesheet';
document.head.appendChild(script); document.head.appendChild(script);
document.head.appendChild(style_sheet); document.head.appendChild(style_sheet);
} }
if ( document.getElementById("font_btns") ){//Show the font selection buttons. //Sets the displayed fontsize.
//This functionality won't work without JavaScript enabled. For this reason the
//buttons won't be shown if this script isn't run.
if ( document.getElementById("font_btns") ){//Show the font selection buttons.
document.getElementById("font_btns").style.display = 'inline'; document.getElementById("font_btns").style.display = 'inline';
var font_size = read_cookie("font_size"); var font_size = read_cookie("font_size");//reads a saved value for fontsize from the site cookie
if ( font_size != "" || font_size != "medium" ){ if ( font_size != "" || font_size != "medium" ){
font_set(font_size); font_set(font_size);//insure a sane default
} }
} }
if ( document.getElementById("search_inputs") ){//Show the search box and button on the tags page. if ( document.getElementById("search_inputs") ){//Show the search box and button on the tags page.
@ -43,7 +48,7 @@ function format_page(){//Set the title of the page based on the main header, <h1
}); });
} }
} }
function font_set(size_to_set){ function font_set(size_to_set){//Set a cookie to remember the fontsize selection.
document.getElementById("article").style.fontSize = size_to_set; document.getElementById("article").style.fontSize = size_to_set;
set_cookie("font_size",size_to_set); set_cookie("font_size",size_to_set);
} }
@ -52,7 +57,7 @@ function focus_element(element_id){
ele_to_focus.focus(); ele_to_focus.focus();
ele_to_focus.select(); ele_to_focus.select();
} }
function tag_search(){ function tag_search(){//searches in the avaliable tags and displays all articles matching the searched tag.
var search_input, filter, tag_list, li, a, i; var search_input, filter, tag_list, li, a, i;
search_input = document.getElementById("tag_sort"); search_input = document.getElementById("tag_sort");
filter = search_input.value.toUpperCase(); filter = search_input.value.toUpperCase();
@ -66,9 +71,8 @@ function tag_search(){
li[i].style.display = "none"; li[i].style.display = "none";
} }
} }
} }
function title_search(){ function title_search(){//searches for matches in the article titles rather than tags. Allows more granular search
var search_input, filter, tag_list, li_list, ol, a, i; var search_input, filter, tag_list, li_list, ol, a, i;
search_input = document.getElementById("title_sort"); search_input = document.getElementById("title_sort");
filter = search_input.value.toUpperCase(); filter = search_input.value.toUpperCase();
@ -88,7 +92,7 @@ function title_search(){
} }
} }
function search_toggle(){ function search_toggle(){//Toggles if the unit being sorted on is the article title or tag
if (document.getElementById("tag_sort")){ if (document.getElementById("tag_sort")){
document.getElementById("tag_sort").placeholder = "Search Titles"; document.getElementById("tag_sort").placeholder = "Search Titles";
document.getElementById("tag_sort").onkeyup = function() {title_search()}; document.getElementById("tag_sort").onkeyup = function() {title_search()};
@ -107,10 +111,10 @@ function search_toggle(){
focus_element("tag_sort"); focus_element("tag_sort");
} }
} }
function set_cookie(prop_name, prop_value){ function set_cookie(prop_name, prop_value){//sets a passed cookie property and value.
document.cookie = prop_name + "=" + prop_value + ";path=/;SameSite=Strict;"; document.cookie = prop_name + "=" + prop_value + ";path=/;SameSite=Strict;";
} }
function read_cookie(cname){ function read_cookie(cname){//reads a property value
let prop_name = cname + '='; let prop_name = cname + '=';
let decoded_cookie = decodeURIComponent(document.cookie); let decoded_cookie = decodeURIComponent(document.cookie);
let split_cookie = decoded_cookie.split(';'); let split_cookie = decoded_cookie.split(';');
@ -125,11 +129,11 @@ function read_cookie(cname){
} }
return ""; return "";
} }
function printDiv(divName) { function printDiv(divName) {//Formats the page for printing.
var printContents = document.getElementById(divName).innerHTML; var printContents = document.getElementById(divName).innerHTML;
w=window.open(); w=window.open();
w.document.write(printContents); w.document.write(printContents);
w.print(); w.print();
w.close(); w.close();
} }
window.onload = format_page; window.onload = format_page;//loades the page formatting script.

View File

@ -1,51 +0,0 @@
<nav id="body_nav" class="jmenu">
<div class="pmenu">
<ul><li><a href=/>Home</a></li></ul>
<?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/get_month_name.php');
function remove_sorting_number($link_title){
$first_three = mb_substr($link_title, 0, 3,"UTF-8");
if ( preg_match( '/[0-9][0-9] /', $first_three) ){
$link_title = mb_substr($link_title,3);
}
return $link_title;
}
$dir = '.';
// Check if the directory exists
if (file_exists($dir) && is_dir($dir) ) {
// Get the files of the directory as an array
$scan_arr = scandir($dir);
$files_arr = array_diff($scan_arr, array('.','..','index.php','common','.htaccess') );
// echo "<pre>"; print_r( $files_arr ); echo "</pre>";
// Get each files of our directory with line break
foreach ($files_arr as $file) {
//Get the file path
$file_path = "./".$file;
// Get the file extension
$file_ext = pathinfo($file_path, PATHINFO_EXTENSION);
if ($file_ext=="php" || $file_ext=="html" || $file_ext=="htm" || $file_ext == "") {
$file_array[] = $file;
}
}
foreach($file_array as $file) {
$_replace = array('.php', '.html', '.htm');
$link_title = str_replace('_',' ',$file);
$link_title = str_replace($_replace,'',$link_title);
$link_title = ucwords($link_title);
$link_title = get_month_name($link_title);
$link_title = remove_sorting_number($link_title);
echo("<ul><li><a href='$file'> $link_title </a></li></ul>\n");
}
}
else {
echo "Directory does not exists";
}
echo("<ul><li><a href='..'>Back</a></li></ul>\n");
?>
</div><!--end of pmenu-->
</nav>
<br>

View File

@ -1,36 +0,0 @@
<table border="1" class="pmenu">
<tr>
<td><a href=/>Home</a></td>
</tr>
<?php
$dir = '.';
// Check if the directory exists
if (file_exists($dir) && is_dir($dir) ) {
// Get the files of the directory as an array
$scan_arr = scandir($dir);
$files_arr = array_diff($scan_arr, array('.','..','index.php','common','.htaccess') );
// echo "<pre>"; print_r( $files_arr ); echo "</pre>";
// Get each files of our directory with line break
foreach ($files_arr as $file) {
//Get the file path
$file_path = "./".$file;
// Get the file extension
$file_ext = pathinfo($file_path, PATHINFO_EXTENSION);
if ($file_ext=="php" || $file_ext=="html" || $file_ext=="htm" || $file_ext == "") {
$file_array[] = $file;
}
}
foreach($file_array as $file) {
$_replace = array('.php', '.html', '.htm');
$link_title = str_replace('_',' ',$file);
$link_title = str_replace($_replace,'',$link_title);
$link_title = ucwords($link_title);
echo("<tr><td><a href='$file'> $link_title </a></td></tr>\n");
}
}
else {
echo "Directory does not exists";
}
?>
</table>

View File

View File

@ -1,11 +1,5 @@
<?php <?php
#Markdown parser dependancy include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/md_read.php');
require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php');
#Markdown parseing code.
$MD_Parser = new ParsedownExtra();
$MD_Path = "article.md";
$MD_File = fopen($MD_Path, "r") or die("File not found.");
$MD_Text = fread($MD_File, filesize($MD_Path));
echo "<article id=\"article\">\n" . /* Adds the option to change the font size of the article text. */ echo "<article id=\"article\">\n" . /* Adds the option to change the font size of the article text. */
"<div id=\"font_btns\"> "<div id=\"font_btns\">
Text Size: Text Size:
@ -24,10 +18,22 @@
<li><a href=\"article.md\" title=\"Download \">MD</a></li> <li><a href=\"article.md\" title=\"Download \">MD</a></li>
</nav> </nav>
". ".
$MD_Parser->text($MD_Text) . "\n</article>"; read_md("article.md") . "\n</article>";
fclose($MD_File);
echo "\n</div><!--End of print-content div-->\n"; echo "\n</div><!--End of print-content div-->\n";
echo("<nav class=\"jmenu\"><div class=\"pmenu\"><ul id=\"back_btn\"><li><a href='..'>Back</a></li></ul></div></nav>\n"); echo("<nav class=\"jmenu\"><div class=\"pmenu\"><ul id=\"back_btn\"><li><a href='..'>Back</a></li></ul></div></nav>\n");
if (file_exists('author') && (filesize('author') != 0)){
$author_name_raw = fopen('author', 'r');
$author_name = fread($author_name_raw, filesize('author'));
$author_name = str_replace("\n", "", $author_name);
$byline_path = $_SERVER['DOCUMENT_ROOT'].'blog/authors/'.$author_name.'/byline.md';
if (file_exists($byline_path)){
echo "<div class =\"byline\">\n"
. read_md($byline_path)
."</div><!--End byline div-->\n";
}
fclose($author_name_raw);
}
if ($tag_data != NULL){ if ($tag_data != NULL){
$page_tags = str_getcsv($tag_data); $page_tags = str_getcsv($tag_data);
natcasesort($page_tags); natcasesort($page_tags);
@ -37,5 +43,5 @@
} }
echo "</ul>\n</div>\n"; echo "</ul>\n</div>\n";
} }
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/modal.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/modal.php');
?> ?>

View File

@ -1,4 +1,5 @@
<?php <?php
//Parses it's passed input to convert it to a month name.
function get_month_name($passed_var){ function get_month_name($passed_var){
switch($passed_var){ switch($passed_var){
case "01": case "01":

View File

@ -1,5 +1,6 @@
<?php <?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/get_month_name.php'); //Sets the proper level 1 heading for the folder.
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/get_month_name.php');
$current_dir = basename(getcwd()); $current_dir = basename(getcwd());
$named_month = get_month_name($current_dir); $named_month = get_month_name($current_dir);
if ( $named_month == "blog") { if ( $named_month == "blog") {

View File

@ -1,20 +1,12 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en-US"> <html lang="en-US">
<?php <?php
//Sets the page title based on the name of the current directory
function Title() { function Title() {
//~ $new_title = $_SERVER['REQUEST_URI'];
//~ $new_title = preg_replace("/^^\//i", "", $new_title);
//~ $new_title = preg_replace("/\//i", "", $new_title);
//~ $page_title = $_SERVER['REQUEST_URI'];
//~ $page_title = preg_replace("/^(.*)\//i", "", $page_title);
$page_title = basename($_SERVER['SCRIPT_FILENAME'], '.php'); $page_title = basename($_SERVER['SCRIPT_FILENAME'], '.php');
//~ echo($page_title);
if(strtolower($page_title) == 'index'){ if(strtolower($page_title) == 'index'){
parse_str($_SERVER['REQUEST_URI'], $page_uri); parse_str($_SERVER['REQUEST_URI'], $page_uri);
$page_path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH); $page_path = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
//~ echo($page_path);
//~ $folder_name = sizeof($page_path);
$folder_name = explode("/", trim($page_path, "/")); $folder_name = explode("/", trim($page_path, "/"));
$page_title = $folder_name[(sizeof($folder_name) - 1)]; $page_title = $folder_name[(sizeof($folder_name) - 1)];
} elseif(strtolower($page_title) == 'homepage'){ } elseif(strtolower($page_title) == 'homepage'){
@ -28,6 +20,7 @@
<head> <head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/> <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<?php <?php
//If a tags file is present parse it and add any tags found to the renderd page's metadata.
if(file_exists('tags')){ if(file_exists('tags')){
$tag_data_raw = fopen('tags',"r"); $tag_data_raw = fopen('tags',"r");
$tag_data = fread($tag_data_raw, filesize('tags')); $tag_data = fread($tag_data_raw, filesize('tags'));
@ -38,10 +31,10 @@
?> ?>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/> <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<title><?php $title = Title(); echo $title;?></title> <title><?php $title = Title(); echo $title;?></title>
<link href="/common/styles.css?v=<?php echo date('his'); ?>" type="text/css" rel="stylesheet"/> <link href="/common/css/styles.css?v=<?php echo date('his'); ?>" type="text/css" rel="stylesheet"/>
<link href="/common/jmenu.css?v=<?php echo date('his'); ?>" type="text/css" rel="stylesheet"/> <link href="/common/css/jmenu.css?v=<?php echo date('his'); ?>" type="text/css" rel="stylesheet"/>
<link href="/common/print.css?v=<?php echo date('his'); ?>" type="text/css" media="print" rel="stylesheet"/> <link href="/common/css/print.css?v=<?php echo date('his'); ?>" type="text/css" media="print" rel="stylesheet"/>
<script type="text/javascript" src="/common/page_format.js?v=<?php echo date('his'); ?>"></script> <script type="text/javascript" src="/common/js/page_format.js?v=<?php echo date('his'); ?>"></script>
</head> </head>
<body lang="en-US"> <body lang="en-US">
<div class="body" id="body"> <div class="body" id="body">

14
common/php/index.php Normal file
View File

@ -0,0 +1,14 @@
<?php
//The common file used to render pages on the blog.
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
//Looks for an article.md to see if the current directory is an article or not
//If it is not then it is a menu page.
if (file_exists('article.md')){
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/article.php');
} else {
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/h1_month.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/page_menu.php');
}
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?>

12
common/php/md_read.php Normal file
View File

@ -0,0 +1,12 @@
<?php
#Markdown parser dependancy
require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php');
function read_md($MD_Path){
#Markdown parseing code.
$MD_Parser = new ParsedownExtra();
$MD_File = fopen($MD_Path, "r") or die("File not found.");
$MD_Text = fread($MD_File, filesize($MD_Path));
return $MD_Parser->text($MD_Text);
fclose($MD_File);
}
?>

54
common/php/page_menu.php Normal file
View File

@ -0,0 +1,54 @@
<nav id="body_nav" class="jmenu">
<div class="pmenu">
<ul><li><a href=/>Home</a></li></ul>
<?php
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/get_month_name.php');
//Removes the number used to keep articles in post order from the displayed title.
function remove_sorting_number($link_title){
$first_three = mb_substr($link_title, 0, 3,"UTF-8");
if ( preg_match( '/[0-9][0-9] /', $first_three) ){
$link_title = mb_substr($link_title,3);
}
return $link_title;
}
$dir = '.';
// Check if the directory exists
if (file_exists($dir) && is_dir($dir) ) {
// Get the files of the directory as an array
$scan_arr = scandir($dir);
$files_arr = array_diff($scan_arr, array('.','..','index.php','common','.htaccess') );
// echo "<pre>"; print_r( $files_arr ); echo "</pre>";
// Get each files of our directory with line break
if (sizeof($files_arr) != 0 ) {
foreach ($files_arr as $file) {
//Get the file path
$file_path = "./".$file;
// Get the file extension
$file_ext = pathinfo($file_path, PATHINFO_EXTENSION);
if ($file_ext=="php" || $file_ext=="html" || $file_ext=="htm" || $file_ext == "") {
$file_array[] = $file;
}
}
foreach($file_array as $file) {//Renders the folder names as more readable titles.
$_replace = array('.php', '.html', '.htm');//Remove file extensions from webpages.
$link_title = str_replace('_',' ',$file);//Remove undersores and replace them with spaces
$link_title = str_replace($_replace,'',$link_title);
$link_title = ucwords($link_title);//Set the first letter of each word to upercase.
$link_title = get_month_name($link_title);//
$link_title = remove_sorting_number($link_title);//Removes the number used to keep articles in post order from the displayed title.
echo("<ul><li><a href='$file'> $link_title </a></li></ul>\n");//Output the result.
}
}
}
else {
echo "Directory does not exists";
}
echo("<ul><li><a href='..'>Back</a></li></ul>\n");
?>
</div><!--end of pmenu-->
</nav>
<br>

View File

@ -37,11 +37,13 @@ namespace Composer\Autoload;
* *
* @author Fabien Potencier <fabien@symfony.com> * @author Fabien Potencier <fabien@symfony.com>
* @author Jordi Boggiano <j.boggiano@seld.be> * @author Jordi Boggiano <j.boggiano@seld.be>
* @see http://www.php-fig.org/psr/psr-0/ * @see https://www.php-fig.org/psr/psr-0/
* @see http://www.php-fig.org/psr/psr-4/ * @see https://www.php-fig.org/psr/psr-4/
*/ */
class ClassLoader class ClassLoader
{ {
private $vendorDir;
// PSR-4 // PSR-4
private $prefixLengthsPsr4 = array(); private $prefixLengthsPsr4 = array();
private $prefixDirsPsr4 = array(); private $prefixDirsPsr4 = array();
@ -55,11 +57,19 @@ class ClassLoader
private $classMap = array(); private $classMap = array();
private $classMapAuthoritative = false; private $classMapAuthoritative = false;
private $missingClasses = array(); private $missingClasses = array();
private $apcuPrefix;
private static $registeredLoaders = array();
public function __construct($vendorDir = null)
{
$this->vendorDir = $vendorDir;
}
public function getPrefixes() public function getPrefixes()
{ {
if (!empty($this->prefixesPsr0)) { if (!empty($this->prefixesPsr0)) {
return call_user_func_array('array_merge', $this->prefixesPsr0); return call_user_func_array('array_merge', array_values($this->prefixesPsr0));
} }
return array(); return array();
@ -271,6 +281,26 @@ class ClassLoader
return $this->classMapAuthoritative; return $this->classMapAuthoritative;
} }
/**
* APCu prefix to use to cache found/not-found classes, if the extension is enabled.
*
* @param string|null $apcuPrefix
*/
public function setApcuPrefix($apcuPrefix)
{
$this->apcuPrefix = function_exists('apcu_fetch') && filter_var(ini_get('apc.enabled'), FILTER_VALIDATE_BOOLEAN) ? $apcuPrefix : null;
}
/**
* The APCu prefix in use, or null if APCu caching is not enabled.
*
* @return string|null
*/
public function getApcuPrefix()
{
return $this->apcuPrefix;
}
/** /**
* Registers this instance as an autoloader. * Registers this instance as an autoloader.
* *
@ -279,6 +309,15 @@ class ClassLoader
public function register($prepend = false) public function register($prepend = false)
{ {
spl_autoload_register(array($this, 'loadClass'), true, $prepend); spl_autoload_register(array($this, 'loadClass'), true, $prepend);
if (null === $this->vendorDir) {
//no-op
} elseif ($prepend) {
self::$registeredLoaders = array($this->vendorDir => $this) + self::$registeredLoaders;
} else {
unset(self::$registeredLoaders[$this->vendorDir]);
self::$registeredLoaders[$this->vendorDir] = $this;
}
} }
/** /**
@ -287,6 +326,10 @@ class ClassLoader
public function unregister() public function unregister()
{ {
spl_autoload_unregister(array($this, 'loadClass')); spl_autoload_unregister(array($this, 'loadClass'));
if (null !== $this->vendorDir) {
unset(self::$registeredLoaders[$this->vendorDir]);
}
} }
/** /**
@ -313,11 +356,6 @@ class ClassLoader
*/ */
public function findFile($class) public function findFile($class)
{ {
// work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731
if ('\\' == $class[0]) {
$class = substr($class, 1);
}
// class map lookup // class map lookup
if (isset($this->classMap[$class])) { if (isset($this->classMap[$class])) {
return $this->classMap[$class]; return $this->classMap[$class];
@ -325,6 +363,12 @@ class ClassLoader
if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) { if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) {
return false; return false;
} }
if (null !== $this->apcuPrefix) {
$file = apcu_fetch($this->apcuPrefix.$class, $hit);
if ($hit) {
return $file;
}
}
$file = $this->findFileWithExtension($class, '.php'); $file = $this->findFileWithExtension($class, '.php');
@ -333,6 +377,10 @@ class ClassLoader
$file = $this->findFileWithExtension($class, '.hh'); $file = $this->findFileWithExtension($class, '.hh');
} }
if (null !== $this->apcuPrefix) {
apcu_add($this->apcuPrefix.$class, $file);
}
if (false === $file) { if (false === $file) {
// Remember that this class does not exist. // Remember that this class does not exist.
$this->missingClasses[$class] = true; $this->missingClasses[$class] = true;
@ -341,6 +389,16 @@ class ClassLoader
return $file; return $file;
} }
/**
* Returns the currently registered loaders indexed by their corresponding vendor directories.
*
* @return self[]
*/
public static function getRegisteredLoaders()
{
return self::$registeredLoaders;
}
private function findFileWithExtension($class, $ext) private function findFileWithExtension($class, $ext)
{ {
// PSR-4 lookup // PSR-4 lookup
@ -348,10 +406,14 @@ class ClassLoader
$first = $class[0]; $first = $class[0];
if (isset($this->prefixLengthsPsr4[$first])) { if (isset($this->prefixLengthsPsr4[$first])) {
foreach ($this->prefixLengthsPsr4[$first] as $prefix => $length) { $subPath = $class;
if (0 === strpos($class, $prefix)) { while (false !== $lastPos = strrpos($subPath, '\\')) {
foreach ($this->prefixDirsPsr4[$prefix] as $dir) { $subPath = substr($subPath, 0, $lastPos);
if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) { $search = $subPath . '\\';
if (isset($this->prefixDirsPsr4[$search])) {
$pathEnd = DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $lastPos + 1);
foreach ($this->prefixDirsPsr4[$search] as $dir) {
if (file_exists($file = $dir . $pathEnd)) {
return $file; return $file;
} }
} }

View File

@ -0,0 +1,302 @@
<?php
/*
* This file is part of Composer.
*
* (c) Nils Adermann <naderman@naderman.de>
* Jordi Boggiano <j.boggiano@seld.be>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Composer;
use Composer\Autoload\ClassLoader;
use Composer\Semver\VersionParser;
/**
* This class is copied in every Composer installed project and available to all
*
* To require it's presence, you can require `composer-runtime-api ^2.0`
*/
class InstalledVersions
{
private static $installed = array (
'root' =>
array (
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'aliases' =>
array (
),
'reference' => 'ad07963e4bb0fe72f9d8399448ed3c30d31e62ed',
'name' => '__root__',
),
'versions' =>
array (
'__root__' =>
array (
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'aliases' =>
array (
),
'reference' => 'ad07963e4bb0fe72f9d8399448ed3c30d31e62ed',
),
'erusev/parsedown' =>
array (
'pretty_version' => '1.7.4',
'version' => '1.7.4.0',
'aliases' =>
array (
),
'reference' => 'cb17b6477dfff935958ba01325f2e8a2bfa6dab3',
),
'erusev/parsedown-extra' =>
array (
'pretty_version' => '0.8.1',
'version' => '0.8.1.0',
'aliases' =>
array (
),
'reference' => '91ac3ff98f0cea243bdccc688df43810f044dcef',
),
),
);
private static $canGetVendors;
private static $installedByVendor = array();
/**
* Returns a list of all package names which are present, either by being installed, replaced or provided
*
* @return string[]
* @psalm-return list<string>
*/
public static function getInstalledPackages()
{
$packages = array();
foreach (self::getInstalled() as $installed) {
$packages[] = array_keys($installed['versions']);
}
if (1 === \count($packages)) {
return $packages[0];
}
return array_keys(array_flip(\call_user_func_array('array_merge', $packages)));
}
/**
* Checks whether the given package is installed
*
* This also returns true if the package name is provided or replaced by another package
*
* @param string $packageName
* @return bool
*/
public static function isInstalled($packageName)
{
foreach (self::getInstalled() as $installed) {
if (isset($installed['versions'][$packageName])) {
return true;
}
}
return false;
}
/**
* Checks whether the given package satisfies a version constraint
*
* e.g. If you want to know whether version 2.3+ of package foo/bar is installed, you would call:
*
* Composer\InstalledVersions::satisfies(new VersionParser, 'foo/bar', '^2.3')
*
* @param VersionParser $parser Install composer/semver to have access to this class and functionality
* @param string $packageName
* @param string|null $constraint A version constraint to check for, if you pass one you have to make sure composer/semver is required by your package
*
* @return bool
*/
public static function satisfies(VersionParser $parser, $packageName, $constraint)
{
$constraint = $parser->parseConstraints($constraint);
$provided = $parser->parseConstraints(self::getVersionRanges($packageName));
return $provided->matches($constraint);
}
/**
* Returns a version constraint representing all the range(s) which are installed for a given package
*
* It is easier to use this via isInstalled() with the $constraint argument if you need to check
* whether a given version of a package is installed, and not just whether it exists
*
* @param string $packageName
* @return string Version constraint usable with composer/semver
*/
public static function getVersionRanges($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
$ranges = array();
if (isset($installed['versions'][$packageName]['pretty_version'])) {
$ranges[] = $installed['versions'][$packageName]['pretty_version'];
}
if (array_key_exists('aliases', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['aliases']);
}
if (array_key_exists('replaced', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['replaced']);
}
if (array_key_exists('provided', $installed['versions'][$packageName])) {
$ranges = array_merge($ranges, $installed['versions'][$packageName]['provided']);
}
return implode(' || ', $ranges);
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['version'])) {
return null;
}
return $installed['versions'][$packageName]['version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as version, use satisfies or getVersionRanges if you need to know if a given version is present
*/
public static function getPrettyVersion($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['pretty_version'])) {
return null;
}
return $installed['versions'][$packageName]['pretty_version'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @param string $packageName
* @return string|null If the package is being replaced or provided but is not really installed, null will be returned as reference
*/
public static function getReference($packageName)
{
foreach (self::getInstalled() as $installed) {
if (!isset($installed['versions'][$packageName])) {
continue;
}
if (!isset($installed['versions'][$packageName]['reference'])) {
return null;
}
return $installed['versions'][$packageName]['reference'];
}
throw new \OutOfBoundsException('Package "' . $packageName . '" is not installed');
}
/**
* @return array
* @psalm-return array{name: string, version: string, reference: string, pretty_version: string, aliases: string[]}
*/
public static function getRootPackage()
{
$installed = self::getInstalled();
return $installed[0]['root'];
}
/**
* Returns the raw installed.php data for custom implementations
*
* @return array[]
* @psalm-return array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[]}, versions: list<string, array{pretty_version: ?string, version: ?string, aliases: ?string[], reference: ?string, replaced: ?string[], provided: ?string[]}>}
*/
public static function getRawData()
{
return self::$installed;
}
/**
* Lets you reload the static array from another file
*
* This is only useful for complex integrations in which a project needs to use
* this class but then also needs to execute another project's autoloader in process,
* and wants to ensure both projects have access to their version of installed.php.
*
* A typical case would be PHPUnit, where it would need to make sure it reads all
* the data it needs from this class, then call reload() with
* `require $CWD/vendor/composer/installed.php` (or similar) as input to make sure
* the project in which it runs can then also use this class safely, without
* interference between PHPUnit's dependencies and the project's dependencies.
*
* @param array[] $data A vendor/composer/installed.php data set
* @return void
*
* @psalm-param array{root: array{name: string, version: string, reference: string, pretty_version: string, aliases: string[]}, versions: list<string, array{pretty_version: ?string, version: ?string, aliases: ?string[], reference: ?string, replaced: ?string[], provided: ?string[]}>} $data
*/
public static function reload($data)
{
self::$installed = $data;
self::$installedByVendor = array();
}
/**
* @return array[]
*/
private static function getInstalled()
{
if (null === self::$canGetVendors) {
self::$canGetVendors = method_exists('Composer\Autoload\ClassLoader', 'getRegisteredLoaders');
}
$installed = array();
if (self::$canGetVendors) {
// @phpstan-ignore-next-line
foreach (ClassLoader::getRegisteredLoaders() as $vendorDir => $loader) {
if (isset(self::$installedByVendor[$vendorDir])) {
$installed[] = self::$installedByVendor[$vendorDir];
} elseif (is_file($vendorDir.'/composer/installed.php')) {
$installed[] = self::$installedByVendor[$vendorDir] = require $vendorDir.'/composer/installed.php';
}
}
}
$installed[] = self::$installed;
return $installed;
}
}

View File

@ -1,56 +1,19 @@
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ Copyright (c) Nils Adermann, Jordi Boggiano
Upstream-Name: Composer
Upstream-Contact: Jordi Boggiano <j.boggiano@seld.be>
Source: https://github.com/composer/composer
Files: * Permission is hereby granted, free of charge, to any person obtaining a copy
Copyright: 2016, Nils Adermann <naderman@naderman.de> of this software and associated documentation files (the "Software"), to deal
2016, Jordi Boggiano <j.boggiano@seld.be> in the Software without restriction, including without limitation the rights
License: Expat to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is furnished
to do so, subject to the following conditions:
Files: src/Composer/Util/TlsHelper.php The above copyright notice and this permission notice shall be included in all
Copyright: 2016, Nils Adermann <naderman@naderman.de> copies or substantial portions of the Software.
2016, Jordi Boggiano <j.boggiano@seld.be>
2013, Evan Coury <me@evancoury.com>
License: Expat and BSD-2-Clause
License: BSD-2-Clause THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Redistribution and use in source and binary forms, with or without modification, IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
are permitted provided that the following conditions are met: FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
. AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* Redistributions of source code must retain the above copyright notice, LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
this list of conditions and the following disclaimer. OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
. THE SOFTWARE.
* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
License: Expat
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is furnished
to do so, subject to the following conditions:
.
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.

View File

@ -6,4 +6,5 @@ $vendorDir = dirname(dirname(__FILE__));
$baseDir = dirname($vendorDir); $baseDir = dirname($vendorDir);
return array( return array(
'Composer\\InstalledVersions' => $vendorDir . '/composer/InstalledVersions.php',
); );

View File

@ -13,19 +13,24 @@ class ComposerAutoloaderInitae431d6e5e864517dac9bce927d03088
} }
} }
/**
* @return \Composer\Autoload\ClassLoader
*/
public static function getLoader() public static function getLoader()
{ {
if (null !== self::$loader) { if (null !== self::$loader) {
return self::$loader; return self::$loader;
} }
require __DIR__ . '/platform_check.php';
spl_autoload_register(array('ComposerAutoloaderInitae431d6e5e864517dac9bce927d03088', 'loadClassLoader'), true, true); spl_autoload_register(array('ComposerAutoloaderInitae431d6e5e864517dac9bce927d03088', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(); self::$loader = $loader = new \Composer\Autoload\ClassLoader(\dirname(\dirname(__FILE__)));
spl_autoload_unregister(array('ComposerAutoloaderInitae431d6e5e864517dac9bce927d03088', 'loadClassLoader')); spl_autoload_unregister(array('ComposerAutoloaderInitae431d6e5e864517dac9bce927d03088', 'loadClassLoader'));
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION'); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
if ($useStaticLoader) { if ($useStaticLoader) {
require_once __DIR__ . '/autoload_static.php'; require __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInitae431d6e5e864517dac9bce927d03088::getInitializer($loader)); call_user_func(\Composer\Autoload\ComposerStaticInitae431d6e5e864517dac9bce927d03088::getInitializer($loader));
} else { } else {

View File

@ -20,10 +20,15 @@ class ComposerStaticInitae431d6e5e864517dac9bce927d03088
), ),
); );
public static $classMap = array (
'Composer\\InstalledVersions' => __DIR__ . '/..' . '/composer/InstalledVersions.php',
);
public static function getInitializer(ClassLoader $loader) public static function getInitializer(ClassLoader $loader)
{ {
return \Closure::bind(function () use ($loader) { return \Closure::bind(function () use ($loader) {
$loader->prefixesPsr0 = ComposerStaticInitae431d6e5e864517dac9bce927d03088::$prefixesPsr0; $loader->prefixesPsr0 = ComposerStaticInitae431d6e5e864517dac9bce927d03088::$prefixesPsr0;
$loader->classMap = ComposerStaticInitae431d6e5e864517dac9bce927d03088::$classMap;
}, null, ClassLoader::class); }, null, ClassLoader::class);
} }

View File

@ -1,99 +1,113 @@
[ {
{ "packages": [
"name": "erusev/parsedown", {
"version": "1.7.4", "name": "erusev/parsedown",
"version_normalized": "1.7.4.0", "version": "1.7.4",
"source": { "version_normalized": "1.7.4.0",
"type": "git", "source": {
"url": "https://github.com/erusev/parsedown.git", "type": "git",
"reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3" "url": "https://github.com/erusev/parsedown.git",
"reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/erusev/parsedown/zipball/cb17b6477dfff935958ba01325f2e8a2bfa6dab3",
"reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3",
"shasum": ""
},
"require": {
"ext-mbstring": "*",
"php": ">=5.3.0"
},
"require-dev": {
"phpunit/phpunit": "^4.8.35"
},
"time": "2019-12-30T22:54:17+00:00",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-0": {
"Parsedown": ""
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Emanuil Rusev",
"email": "hello@erusev.com",
"homepage": "http://erusev.com"
}
],
"description": "Parser for Markdown.",
"homepage": "http://parsedown.org",
"keywords": [
"markdown",
"parser"
],
"support": {
"issues": "https://github.com/erusev/parsedown/issues",
"source": "https://github.com/erusev/parsedown/tree/1.7.x"
},
"install-path": "../erusev/parsedown"
}, },
"dist": { {
"type": "zip", "name": "erusev/parsedown-extra",
"url": "https://api.github.com/repos/erusev/parsedown/zipball/cb17b6477dfff935958ba01325f2e8a2bfa6dab3", "version": "0.8.1",
"reference": "cb17b6477dfff935958ba01325f2e8a2bfa6dab3", "version_normalized": "0.8.1.0",
"shasum": "" "source": {
}, "type": "git",
"require": { "url": "https://github.com/erusev/parsedown-extra.git",
"ext-mbstring": "*", "reference": "91ac3ff98f0cea243bdccc688df43810f044dcef"
"php": ">=5.3.0" },
}, "dist": {
"require-dev": { "type": "zip",
"phpunit/phpunit": "^4.8.35" "url": "https://api.github.com/repos/erusev/parsedown-extra/zipball/91ac3ff98f0cea243bdccc688df43810f044dcef",
}, "reference": "91ac3ff98f0cea243bdccc688df43810f044dcef",
"time": "2019-12-30 22:54:17", "shasum": ""
"type": "library", },
"installation-source": "dist", "require": {
"autoload": { "erusev/parsedown": "^1.7.4"
"psr-0": { },
"Parsedown": "" "require-dev": {
} "phpunit/phpunit": "^4.8.35"
}, },
"notification-url": "https://packagist.org/downloads/", "time": "2019-12-30T23:20:37+00:00",
"license": [ "type": "library",
"MIT" "installation-source": "dist",
], "autoload": {
"authors": [ "psr-0": {
{ "ParsedownExtra": ""
"name": "Emanuil Rusev", }
"email": "hello@erusev.com", },
"homepage": "http://erusev.com" "notification-url": "https://packagist.org/downloads/",
} "license": [
], "MIT"
"description": "Parser for Markdown.", ],
"homepage": "http://parsedown.org", "authors": [
"keywords": [ {
"markdown", "name": "Emanuil Rusev",
"parser" "email": "hello@erusev.com",
] "homepage": "http://erusev.com"
}, }
{ ],
"name": "erusev/parsedown-extra", "description": "An extension of Parsedown that adds support for Markdown Extra.",
"version": "0.8.1", "homepage": "https://github.com/erusev/parsedown-extra",
"version_normalized": "0.8.1.0", "keywords": [
"source": { "markdown",
"type": "git", "markdown extra",
"url": "https://github.com/erusev/parsedown-extra.git", "parsedown",
"reference": "91ac3ff98f0cea243bdccc688df43810f044dcef" "parser"
}, ],
"dist": { "support": {
"type": "zip", "issues": "https://github.com/erusev/parsedown-extra/issues",
"url": "https://api.github.com/repos/erusev/parsedown-extra/zipball/91ac3ff98f0cea243bdccc688df43810f044dcef", "source": "https://github.com/erusev/parsedown-extra/tree/0.8.x"
"reference": "91ac3ff98f0cea243bdccc688df43810f044dcef", },
"shasum": "" "install-path": "../erusev/parsedown-extra"
}, }
"require": { ],
"erusev/parsedown": "^1.7.4" "dev": true,
}, "dev-package-names": []
"require-dev": { }
"phpunit/phpunit": "^4.8.35"
},
"time": "2019-12-30 23:20:37",
"type": "library",
"installation-source": "dist",
"autoload": {
"psr-0": {
"ParsedownExtra": ""
}
},
"notification-url": "https://packagist.org/downloads/",
"license": [
"MIT"
],
"authors": [
{
"name": "Emanuil Rusev",
"email": "hello@erusev.com",
"homepage": "http://erusev.com"
}
],
"description": "An extension of Parsedown that adds support for Markdown Extra.",
"homepage": "https://github.com/erusev/parsedown-extra",
"keywords": [
"markdown",
"markdown extra",
"parsedown",
"parser"
]
}
]

42
common/vendor/composer/installed.php vendored Normal file
View File

@ -0,0 +1,42 @@
<?php return array (
'root' =>
array (
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'aliases' =>
array (
),
'reference' => 'ad07963e4bb0fe72f9d8399448ed3c30d31e62ed',
'name' => '__root__',
),
'versions' =>
array (
'__root__' =>
array (
'pretty_version' => 'dev-master',
'version' => 'dev-master',
'aliases' =>
array (
),
'reference' => 'ad07963e4bb0fe72f9d8399448ed3c30d31e62ed',
),
'erusev/parsedown' =>
array (
'pretty_version' => '1.7.4',
'version' => '1.7.4.0',
'aliases' =>
array (
),
'reference' => 'cb17b6477dfff935958ba01325f2e8a2bfa6dab3',
),
'erusev/parsedown-extra' =>
array (
'pretty_version' => '0.8.1',
'version' => '0.8.1.0',
'aliases' =>
array (
),
'reference' => '91ac3ff98f0cea243bdccc688df43810f044dcef',
),
),
);

View File

@ -0,0 +1,26 @@
<?php
// platform_check.php @generated by Composer
$issues = array();
if (!(PHP_VERSION_ID >= 50300)) {
$issues[] = 'Your Composer dependencies require a PHP version ">= 5.3.0". You are running ' . PHP_VERSION . '.';
}
if ($issues) {
if (!headers_sent()) {
header('HTTP/1.1 500 Internal Server Error');
}
if (!ini_get('display_errors')) {
if (PHP_SAPI === 'cli' || PHP_SAPI === 'phpdbg') {
fwrite(STDERR, 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . implode(PHP_EOL, $issues) . PHP_EOL.PHP_EOL);
} elseif (!headers_sent()) {
echo 'Composer detected issues in your platform:' . PHP_EOL.PHP_EOL . str_replace('You are running '.PHP_VERSION.'.', '', implode(PHP_EOL, $issues)) . PHP_EOL.PHP_EOL;
}
}
trigger_error(
'Composer detected issues in your platform: ' . implode(' ', $issues),
E_USER_ERROR
);
}

View File

@ -1,6 +1,6 @@
<?php <?php
include ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
?> ?>
<article> <article>
<h1 title="Homepage for <?php $site = $_SERVER['SERVER_NAME'];echo"$site";?>">Homepage</h1> <h1 title="Homepage for <?php $site = $_SERVER['SERVER_NAME'];echo"$site";?>">Homepage</h1>
@ -11,5 +11,5 @@ include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php');
</div> </div>
</article> </article>
<?php <?php
include ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php'); include ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?> ?>

View File

@ -1,7 +1,7 @@
<?php <?php
require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php'); require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
#Markdown parseing code. #Markdown parseing code.
$MD_Parser = new Parsedown(); $MD_Parser = new Parsedown();
$MD_Path = "gplv2.md"; $MD_Path = "gplv2.md";
@ -10,5 +10,5 @@
echo "<article>".$MD_Parser->text($MD_Text); echo "<article>".$MD_Parser->text($MD_Text);
fclose($MD_File); fclose($MD_File);
echo "<p>A text version of this document can be found <a href=\"/GPLv2.txt\">here</a>.</p>\n</article>"; echo "<p>A text version of this document can be found <a href=\"/GPLv2.txt\">here</a>.</p>\n</article>";
include ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php'); include ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?> ?>

View File

@ -1,7 +1,7 @@
<?php <?php
require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php'); require ($_SERVER['DOCUMENT_ROOT'].'/common/vendor/autoload.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
echo "<article>"; echo "<article>";
?> ?>
<p>The MIT License (MIT)</p> <p>The MIT License (MIT)</p>
@ -15,5 +15,5 @@
<p>THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.</p> <p>THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.</p>
<?php <?php
echo "<p>A text version of this document can be found <a href=\"/license/MIT.txt\">here</a>.</p>\n</article>"; echo "<p>A text version of this document can be found <a href=\"/license/MIT.txt\">here</a>.</p>\n</article>";
include ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php'); include ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');
?> ?>

View File

@ -3,8 +3,8 @@ function display_file($license_file){
$out = file_get_contents($license_file); $out = file_get_contents($license_file);
echo "<pre><code>".$out."</code></pre>"; echo "<pre><code>".$out."</code></pre>";
} }
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/header.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/header.php');
include_once ($_SERVER['DOCUMENT_ROOT'].'/common/menu.php'); include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/menu.php');
?> ?>
<article> <article>
<p>A summery of all licenses that apply to this website.</p> <p>A summery of all licenses that apply to this website.</p>
@ -57,4 +57,4 @@ You can learn more on <a href="https://prismjs.com/">prismjs.com</a>.</p></block
Prism is <a href="/license/MIT.php">MIT Licensed</a>.</p> Prism is <a href="/license/MIT.php">MIT Licensed</a>.</p>
<?php display_file("MIT_License.txt"); ?> <?php display_file("MIT_License.txt"); ?>
</article> </article>
<?php include_once ($_SERVER['DOCUMENT_ROOT'].'/common/footer.php');?> <?php include_once ($_SERVER['DOCUMENT_ROOT'].'/common/php/footer.php');?>