aboutsummaryrefslogtreecommitdiff
path: root/doc/tips/github.mdwn
blob: 6011a450f8fcc866c43e096cae3b58c448e0b878 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
[[!meta date="2008-12-29 14:58:54 -0500"]]

Here's how to set up a static wiki or blog using ikiwiki with no hosting
fees. Everything is hosted on github, both the git repository and the web
site. Your laptop is used to generate and publish changes to it.

This is possible because github now supports
[github pages](http://github.com/blog/272-github-pages).

Note that github limits free accounts to 100 MB of git storage. It's
unlikely that a small wiki or blog will outgrow this, but we are keeping
two copies of the website in git (source and the compiled site), and all
historical versions too. So it could happen. If it does, you can pay github
for more space, or you can migrate your site elsewhere.

## Github Setup

* Go to [github](http://github.com/) and sign up for an account, if you haven't already. 
* Be sure to add your laptop's ssh key to it so you can push to github.
* Create a repository on github named `$YOU.github.com`, substituting your
  *username*. This repository will be used to publish your compiled website.
* Create a repository on github named `$YOU` (or anything else you like).
  This repository will be used to publish the source of your website.
  This is actually optional.

## Local Setup

* On your laptop, create two empty git repositories to correspond to the github repositories: <br />
	`YOU=your github username here` <br />
	`mkdir ~/$YOU.github.com` <br />
	`cd ~/$YOU.github.com` <br />
	`git init` <br />
	`git remote add origin git@github.com:$YOU/$YOU.github.com.git` <br />
	`mkdir ~/$YOU` <br />
	`cd ~/$YOU` <br />
	`git init` <br />
	`git remote add origin git@github.com:$YOU/$YOU.git` <br />
* Add some wiki pages, such as an `index.mdwn`, to `~/$YOU`, and check them
  in and commit them to git. You need something to push to github. Run
  `git push origin master` to push the source pages to github.

## Publishing to Github

* Now build your wiki with a command such as: <br />
	`ikiwiki ~/$YOU ~/$YOU.github.com --refresh`
* Each time you build the wiki you will need to commit the changes
  to git, and push the compiled pages to github: <br />
	`cd ~/YOU.github.com` <br />
	`git add .` <br />
	`git commit -a -m update` <br />
	`git push origin master` <br />

Your wiki will show up at `http://$YOU.github.com/` within ten
minutes after the first push, and changes you push to it from then on
should show up immediately.

## Enhancements

You can follow the instructions in [[laptop_wiki_with_git]] to set up an
editable version of your wiki on your laptop. Then you can use the web
interface for editing. You'll still need to follow the instructions above
to publish your changes to github.

It would also be possible to teach ikiwiki to push compiled pages to github
itself via a plugin, as was done with the [[plugins/amazon_s3]] plugin. Not
done yet!