-
Notifications
You must be signed in to change notification settings - Fork 0
host markdown files & render as html
License
kennykarnama/md-hoster
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
## Introduction Simple markdown hoster. Upload tar.gz containing your markdown files and assets. Displays as html. This is only my learning projects to learn more about C :D Feel free to use and modify. Cheers :D FYI: This project (repo) is used for my personal website (https://www.kokobow.fun) So please expects you will find unrelated things: - me/ (holds welcoming page) - heroku.yml (for my personal website deployment platform) ## How to use prerequisite: Compile cli & server (please go to section #compile) Suppose you have directory with the following structures ``` + pages / + index.md + page1.md ``` Archive it first using provided cli binary (see section #Uploading) It will output the file in format [uuid].tar.gz Upload your files, use postman collection provided in misc/postman_collection.json Once upload done, server will store your tar.gz and extract the archives to ``` md/out/[your_file].tar.gz/ ``` To access your site, simply go to: ``` [base_url]/md/out/test.tar.gz/index.md ``` Note: Server doesn't save any states of uploading files. So if you deploy in a platform that uses ephemeral storage, your uploaded files will be lost if you reboot the server ## compile - dependencies + https://www.libarchive.org/ + https://sourceforge.net/projects/libuuid/ + https://www.gnu.org/software/libmicrohttpd/ + /~https://github.com/mity/md4c ``` gcc cmd/cli.c -o bin/cli -larchive -luuid ``` ## compile server ``` gcc cmd/server.c -o bin/server -larchive -luuid -lmicrohttpd -lmd4c-html ``` ## Uploading ls -d -1 sample_md/* | ./cli ## Server ``` ./bin/server ``` It will serve HTTP on PORT 8080 To terminate, simply type any character then press enter. Note: If you have successfully compiled server.c but when running you encounter message like this: ``` ./bin/server: error while loading shared libraries: libmd4c-html.so.0: cannot open shared object file: No such file or directory ``` The workaround I use is to specify LD_LIBRARY_PATH to /usr/local/lib64: ``` [kenny_void@(none) md-hoster]$ LD_LIBRARY_PATH=/usr/local/lib64 [kenny_void@(none) md-hoster]$ export LD_LIBRARY_PATH [kenny_void@(none) md-hoster]$ sudo ldconfig ``` ## Valgrind Version: 3.20.0 ``` valgrind --leak-check=yes --track-origins=yes ./bin/server ``` Latest report ``` ==30205== ==30205== HEAP SUMMARY: ==30205== in use at exit: 0 bytes in 0 blocks ==30205== total heap usage: 1,018 allocs, 1,018 frees, 844,804 bytes allocated ==30205== ==30205== All heap blocks were freed -- no leaks are possible ==30205== ==30205== For lists of detected and suppressed errors, rerun with: -s ==30205== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0) ```
About
host markdown files & render as html
Topics
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published