1
0
mirror of https://github.com/schollz/cowyo.git synced 2023-08-10 21:13:00 +03:00
cowyo/README.md

154 lines
7.5 KiB
Markdown
Raw Normal View History

2016-03-19 17:30:02 +03:00
![Logo](/static/img/cowyo.png)
2016-02-08 05:59:35 +03:00
2016-03-21 02:03:48 +03:00
# [cowyo.com](http://cowyo.com/)
2016-03-19 18:47:04 +03:00
2016-03-29 03:20:47 +03:00
[![Version 0.95](https://img.shields.io/badge/version-0.95-brightgreen.svg)]() [![Go Report Card](https://goreportcard.com/badge/github.com/schollz/cowyo)](https://goreportcard.com/report/github.com/schollz/cowyo) [![Join the chat at https://gitter.im/schollz/cowyo](https://badges.gitter.im/schollz/cowyo.svg)](https://gitter.im/schollz/cowyo?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
2016-02-08 05:59:35 +03:00
2016-03-19 18:47:04 +03:00
This is a self-contained notepad webserver that makes sharing easy and _fast_. The most important feature here is *simplicity*. There are many other features as well including versioning, page locking, self-destructing messages, encryption, math support, and listifying. Read on to learn more about the features.
2016-02-08 05:59:35 +03:00
2016-02-10 20:52:12 +03:00
# Features
2016-03-19 18:33:31 +03:00
**Simplicity**. The philosophy here is to *just type*. To jot a note, simply load the page at [`/`](http://cowyo.com/) and just start typing. No need to press edit, the browser will already be focused on the text. No need to press save - it will automatically save when you stop writing. The URL at [`/`](http://cowyo.com/) will redirect to an easy-to-remember name that you can use to reload the page at anytime, anywhere. But, you can also use any URL you want, e.g. [`/AnythingYouWant`](http://cowyo.com/AnythingYouWant). All pages can be rendered into HTML by adding `/view`. For example, the page [`/AnythingYouWant`](http://cowyo.com/AnythingYouWant) is rendered at [`/AnythingYouWant/view`](http://cowyo.com/AnythingYouWant/view). You can write in HTML or [Markdown](https://daringfireball.net/projects/markdown/) for page rendering. To quickly link to `/view` pages, just use `[[AnythingYouWant]]`.
2016-02-08 05:59:35 +03:00
2016-03-19 18:11:09 +03:00
![Simply type to edit.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help1.gif)
2016-03-14 18:26:23 +03:00
2016-03-15 04:39:09 +03:00
<br>
2016-03-19 18:26:08 +03:00
**Listifying**. If you are writing a list and you want to tick off things really easily, just add `/list`. For example, after editing [`/grocery`](http://cowyo.com/grocery), goto [`/grocery/list`](http://cowyo.com/grocery/list). In this page, whatever you click on will be struck through and moved to the end. This is helpful if you write a grocery list and then want to easily delete things from it.
2016-02-10 17:01:20 +03:00
2016-03-19 18:11:09 +03:00
![Lists are easy to make.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help2.gif)
2016-03-14 18:26:23 +03:00
2016-03-18 03:11:49 +03:00
<br>
**Page locking**. Pages can be locked by providing a password to prevent further editing. The whole version tree will still be available. _Note_: This is not available for list mode.
2016-03-19 18:11:09 +03:00
![Locking is easy.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help3.gif)
2016-03-18 03:11:49 +03:00
2016-03-15 04:39:09 +03:00
<br>
**Automatic versioning**. All previous versions of all notes are stored and can be accessed by adding `?version=X` onto `/view` or `/edit`. If you are on the `/view` or `/edit` pages the menu below will show the most substantial changes in the history. Note, only the _current_ version can be edited (no branching allowed, yet).
2016-02-10 17:01:20 +03:00
2016-03-19 18:11:09 +03:00
![Versioning is easy.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help4.gif)
2016-03-14 18:26:23 +03:00
2016-03-15 04:39:09 +03:00
<br>
2016-03-14 18:26:23 +03:00
**Self-destructing messages**. You can write a message that will delete itself when a user loads it (in any view). Useful for transmitting sensitive information. To use, simply add a line somewhere that says only "`self-destruct`".
2016-03-19 18:11:09 +03:00
![Mission impossible style self-destruction.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help5.gif)
2016-03-14 18:26:23 +03:00
2016-03-15 04:39:09 +03:00
<br>
**Security**. HTTPS support is provided and everything is sanitized to prevent XSS attacks. Though all URLs are publicly accessible, you are free to obfuscate your website by using an obscure/random address (read: the site is still publicly accessible, just hard to find!). In addition to TLS support, you can PGP-encrypt your messages using a passphrase (_Note: This will delete the version tree_).
2016-03-14 18:26:23 +03:00
2016-03-19 18:11:09 +03:00
![Security and encryption baked in.](https://raw.githubusercontent.com/schollz/cowyo/master/static/img/help6.gif)
2016-02-14 04:45:09 +03:00
2016-03-15 04:39:09 +03:00
<br>
**CLI support**. Want to upload/download from a server? Its super easy. Upload/download files like this:
```bash
$ echo "Hello, world!" > hi.txt
$ curl -L --upload-file hi.txt cowyo.com
File uploaded to http://cowyo.com/hi.txt
$ curl -L cowyo.com/test.txt
Hello, world!
```
or just skip the file-creation step,
```bash
$ echo "Wow, so easy" | curl -L --upload-file "-" cowyo.com
File uploaded to http://cowyo.com/CautiousCommonLoon
$ curl -L cowyo.com/CautiousCommonLoon
Wow, so easy
```
<br>
2016-03-15 04:39:09 +03:00
**Keyboard Shortcuts**. Quickly transition between Edit/View/List by using `Ctl+Shift+E` to Edit, `Ctl+Shift+Z` to View, and `Ctl+Shift+L` to Listify.
2016-02-14 04:45:09 +03:00
**Admin controls**. The Admin can view/delete all the documents by setting the `-a YourAdminKey` when starting the program. Then the admin has access to the `/ls/YourAdminKey` to view and delete any of the pages.
2016-02-11 05:19:12 +03:00
2016-03-15 04:39:09 +03:00
**Math support**. Math is supported with [Katex](https://github.com/Khan/KaTeX) using `$\frac{1}{2}$` for inline equations and `$$\frac{1}{2}$$` for regular equations.
2016-03-14 18:35:30 +03:00
2016-03-14 18:26:23 +03:00
2016-02-10 17:01:20 +03:00
# Install
2016-02-14 07:19:40 +03:00
2016-02-14 18:04:50 +03:00
First [install Go](https://golang.org/doc/install). Then continue.
2016-02-14 07:19:40 +03:00
2016-02-14 18:04:50 +03:00
## To access locally...
2016-02-14 07:19:40 +03:00
Then, if you want to host on your local network just do:
```
2016-03-19 18:26:08 +03:00
git clone https://github.com/schollz/cowyo.git
cd cowyo
make
2016-03-19 18:26:08 +03:00
./cowyo -p :8001 LOCALIPADDRESS
```
and then goto the address `http://LOCALIPADDRESS:8001/`
2016-02-08 06:01:26 +03:00
2016-02-14 18:04:50 +03:00
## To access from anywhere...
For this you need to forward port 80 and [get a DNS for your external address](https://www.duckdns.org/). I recommend using `NGINX` as middleware, as it will do caching of the static files for you.
```bash
sudo apt-get install nginx
```
There is an example `NGINX` block in `install/`. If you want to use SSL instead, follow the instructions in `letsencrypt/README.md`. To automatically install, on Raspberry Pi / Ubuntu / Debian system use:
```
2016-03-19 18:26:08 +03:00
git clone https://github.com/schollz/cowyo.git
cd cowyo
2016-02-10 20:52:12 +03:00
nano Makefile <--- EDIT this Makefile to include YOUR EXTERNAL ADDRESS
make && sudo make install
```
Now the program starts and stops with
```
2016-03-19 18:26:08 +03:00
sudo /etc/init.d/cowyo start|stop|restart
```
Edit your crontab (`sudo crontab -e`) to start on boot:
```
2016-03-19 18:26:08 +03:00
@reboot /etc/init.d/cowyo start
```
2016-02-08 18:33:39 +03:00
2016-02-08 06:01:26 +03:00
# Usage
```
2016-03-19 18:26:08 +03:00
$ cowyo --help
cowyo: A Websocket Wiki and Kind Of A List Application
2016-02-08 06:01:26 +03:00
run this to start the server and then visit localhost at the port you specify
(see parameters).
2016-03-19 18:26:08 +03:00
Example: 'cowyo localhost'
Example: 'cowyo -p :8080 localhost:8080'
Example: 'cowyo -db /var/lib/cowyo/db.bolt localhost:8003'
Example: 'cowyo -p :8080 -crt ssl/server.crt -key ssl/server.key localhost:8080'
2016-02-08 06:01:26 +03:00
Options:
2016-02-09 01:47:07 +03:00
-a string
key to access admin priveleges (default no admin priveleges)
2016-02-08 06:01:26 +03:00
-crt string
location of ssl crt
-db string
2016-03-19 18:26:08 +03:00
location of database file (default "/home/mu/cowyo/data.db")
2016-02-08 06:01:26 +03:00
-httptest.serve string
if non-empty, httptest.NewServer serves on this address and blocks
-key string
location of ssl key
-p string
2016-02-10 23:07:26 +03:00
port to bind (default ":8003")
2016-02-10 17:01:20 +03:00
```
2016-02-10 04:23:48 +03:00
If you set the admin flag, `-a` you can access a list of all the current files by going to `/ls/WhateverYouSetTheFlagTo`.
2016-02-10 20:52:12 +03:00
# Contact
2016-03-19 18:26:08 +03:00
If you'd like help, go ahead and clone and send a pull request. If you find a bug, please submit [an issue](https://github.com/schollz/cowyo/issues). Any other comments, questions or anything at all, just <a href="https://twitter.com/intent/tweet?screen_name=zack_118" class="twitter-mention-button" data-related="zack_118">tweet me @zack_118</a>
2016-02-10 20:52:12 +03:00
# Contributors
Thanks to [tscholl2](https://github.com/tscholl2).
2016-03-19 18:52:09 +03:00
Icons made by [Freepik](http://www.freepik.com) from [www.flaticon.com](http://www.flaticon.com) is licensed by <a href="http://creativecommons.org/licenses/by/3.0/" title="Creative Commons BY 3.0" target="_blank">CC 3.0 BY</a>