mirror of
				https://github.com/iiab/iiab.git
				synced 2025-03-09 15:40:17 +00:00 
			
		
		
		
	
						commit
						f62b60f288
					
				
					 3 changed files with 40 additions and 21 deletions
				
			
		|  | @ -1,6 +1,6 @@ | |||
| Contributing to Internet-in-a-Box (IIAB) | ||||
| ======================================= | ||||
| Internet-in-a-Box runs on various GNU/Linux operating systems such as Fedora, Ubuntu, Debian, CentOS and Raspbian. | ||||
| Internet-in-a-Box runs on various GNU/Linux operating systems such as Raspbian, Ubuntu, Debian, CentOS and Fedora. | ||||
| 
 | ||||
| You can install Internet-in-a-Box on x86_64 PCs/laptops and Raspberry Pi 3 (or 3 B+).  Example PC's include Intel NUC and Gigabyte BRIX.  Partial support is also available on OLPC laptops like the XO-1.5, XO-1.75 and XO-4.  A VirtualBox VM can also be used for testing purposes.  Using Docker containers however is not recommended as our Ansible provisioning system requires low-level access to the operating system. | ||||
| 
 | ||||
|  | @ -8,7 +8,7 @@ Finally, running Internet-in-a-Box on the Raspberry Pi Zero W is also possible, | |||
| 
 | ||||
| Please refer to [IIAB Platforms](https://github.com/iiab/iiab/wiki/IIAB-Platforms) for more information. | ||||
| 
 | ||||
| Internet-in-a-Box uses [Ansible](https://www.ansible.com/) infrastructure automation tool to deploy and configure all software packages. Ansible uses [playbooks](http://docs.ansible.com/ansible/latest/playbooks.html) a human readable instruction files in YAML format. Playbooks are divided into hosts, roles and tasks. | ||||
| Internet-in-a-Box uses Ansible (acquired by Red Hat in October 2015, similar to Puppet) to install and configure all software packages.  Ansible uses [playbooks](http://docs.ansible.com/ansible/latest/playbooks.html) as human-readable instruction files in [YAML](http://www.yaml.org/start.html) format.  Playbooks are divided into hosts, roles and tasks. | ||||
| ``` | ||||
| ├── roles | ||||
| │   ├── 1-prep | ||||
|  | @ -18,36 +18,54 @@ Internet-in-a-Box uses [Ansible](https://www.ansible.com/) infrastructure automa | |||
| │   │   ├── tasks | ||||
| |   |   |    ├──main.yml (specifies the actions to install this role | ||||
| │   │   └── templates | ||||
| |   |   |    ├──<text files where ansible variables are substituted, specified via {% <variable> %} containers-(jinja2 language)> | ||||
| |   |   |    ├──<text files where Ansible variables are substituted, using jinja2 templating e.g. {% <variable> %}> | ||||
| │   ├── 2-common | ||||
| │   │   ├── README.rst | ||||
| │   │   ├── tasks | ||||
| │   │   └── templates | ||||
| ``` | ||||
| At runtime, Ansible gathers system information and makes it available (called 'facts') and combines this with playbook defined 'variables' to guide the installation process. The execution follows a sequence of cascading steps: | ||||
| Specifically, Ansible installs Internet-in-a-Box starting with 0-init, followed by Stages 1 to 9, and finally runs the network stage: | ||||
| - [0-init](https://github.com/iiab/iiab/tree/master/roles/0-init) | ||||
| - [1-prep](https://github.com/iiab/iiab/tree/master/roles/1-prep) | ||||
| - [2-common](https://github.com/iiab/iiab/tree/master/roles/2-common) | ||||
| - [3-base-server](https://github.com/iiab/iiab/tree/master/roles/3-base-server) | ||||
| - [4-server-options](https://github.com/iiab/iiab/tree/master/roles/4-server-options) | ||||
| - [5-xo-services](https://github.com/iiab/iiab/tree/master/roles/5-xo-services) | ||||
| - [6-generic-apps](https://github.com/iiab/iiab/tree/master/roles/6-generic-apps) | ||||
| - [7-edu-apps](https://github.com/iiab/iiab/tree/master/roles/7-edu-apps) | ||||
| - [8-mgmt-tools](https://github.com/iiab/iiab/tree/master/roles/8-mgmt-tools) | ||||
| - [9-local-addons](https://github.com/iiab/iiab/tree/master/roles/9-local-addons) | ||||
| - [network](https://github.com/iiab/iiab/tree/master/roles/network) | ||||
| 
 | ||||
| 1. Bash script `./iiab-install` follows instructions in `iiab-stages.yml` in the root directory. | ||||
| Click on Stages 1 to 9 above for descriptions of their specific purposes. | ||||
| 
 | ||||
| 2. `iiab-stages.yml` calls 9 aggregate roles (AKA stages, these are the numbered directories under `./roles/`) and then the network role.  (Aside: the network role can also later be run using `./iiab-network`) | ||||
| At runtime (to build up your Internet-in-a-Box server) Ansible gathers system information making it available (as 'facts') and combines this with Ansible 'variables' to guide the installation process. The execution follows a sequence of cascading steps: | ||||
| 
 | ||||
| 3. Each aggregate role AKA stage has a `<role>/meta/main.yml` which calls its needed roles. | ||||
| 1. Bash script `./iiab-install` uses Ansible to run `/opt/iiab/iiab/iiab-stages.yml` | ||||
| 
 | ||||
| 2. `iiab-stages.yml` calls 9+ aggregate roles (AKA stages, these are the numbered directories above, in /opt/iiab/iiab/roles) and then the network role.  It avoids repeating any of these 9 core install stages (in case of Internet glitches etc) by keeping a counter ("STAGE") in `/etc/iiab/iiab.env`  (Aside: the network role can also later be run using `./iiab-network`) | ||||
| 
 | ||||
| 3. Each aggregate role AKA stage has a `<role>/tasks/main.yml` (formerly `<role>/meta/main.yml`) to invoke all needed roles and tasks. | ||||
| 
 | ||||
| Please refer to the [IIAB Architecture](https://github.com/iiab/iiab/wiki/IIAB-Architecture) and [IIAB Variables]( https://github.com/iiab/iiab/wiki/IIAB-Variables) pages for more information. | ||||
| 
 | ||||
| Installation | ||||
| ============ | ||||
| 
 | ||||
| Before you start the installation please refer to the [hardware section of FAQ](http://wiki.laptop.org/go/IIAB/FAQ#What_hardware_should_I_use.3F) page for memory, storage and network requirements for your platform. Also note that downloading content might take a long time on slower Internet connections. | ||||
| Before you start the installation please refer to the [hardware section of FAQ](http://wiki.laptop.org/go/IIAB/FAQ#What_hardware_should_I_use.3F) page for memory, storage and network requirements for your platform.  Also note that downloading content might take a long time on slower Internet connections. | ||||
| 
 | ||||
| If you are a developer, please consider [building Internet-in-a-Box from scratch](https://github.com/iiab/iiab/wiki/IIAB-Installation#do-everything-from-scratch). | ||||
| Most all implementers should use IIAB's 1-line installer at http://download.iiab.io (click on the version number, e.g. [6.6](http://download.iiab.io/6.6/)). | ||||
| 
 | ||||
| If you are a developer, consider [building Internet-in-a-Box from scratch](https://github.com/iiab/iiab/wiki/IIAB-Installation#do-everything-from-scratch). | ||||
| 
 | ||||
| Please refer to the [IIAB Installation](https://github.com/iiab/iiab/wiki/IIAB-Installation) page for more information. | ||||
| 
 | ||||
| Setting up development environment | ||||
| =================================== | ||||
| 
 | ||||
| ( This section uses experimental development environment for Internet-in-a-Box. It is being developed in the [iiab-dev-mode repository](https://github.com/arky/iiab-dev-mode). ) | ||||
| 
 | ||||
| This section provide a quick setup of Internet-in-a-Box (IIAB) development environment using [Vagrant](https://www.vagrantup.com/). You will need a computer with [virtualization enabled](https://www.virtualbox.org/manual/UserManual.html) and git, Vagrant (2.0 or later) and [VirtualBox](https://www.virtualbox.org/) installed. | ||||
| This section provide a quick setup of Internet-in-a-Box (IIAB) development environment using [Vagrant](https://www.vagrantup.com/).  You will need a computer with [virtualization enabled](https://www.virtualbox.org/manual/UserManual.html) and git, Vagrant (2.0 or later) and [VirtualBox](https://www.virtualbox.org/) installed. | ||||
| 
 | ||||
| ## Requirements | ||||
| 
 | ||||
|  | @ -57,14 +75,15 @@ This section provide a quick setup of Internet-in-a-Box (IIAB) development envir | |||
|  * Editor ([Atom](www.atom.io), Emacs, vi, etc) | ||||
| 
 | ||||
| ## Setup Instructions | ||||
| 
 | ||||
| 1. Check out the repository and its submodules onto your development machine. | ||||
| `git clone --recursive git@github.com:arky/iiab-dev-mode.git` | ||||
| 
 | ||||
| 2. Change directory into 'iiab-dev-mode' with `cd iiab-dev-mode`. You can update all the submodules to latest master using `git submodule foreach git pull origin master` | ||||
| 2. Change directory into 'iiab-dev-mode' with `cd iiab-dev-mode`.  You can update all the submodules to the latest master using `git submodule foreach git pull origin master` | ||||
| 
 | ||||
| 3. Set up a vagrant machine with `vagrant up` and provision it with `vagrant provision`. Please select the available bridge network interface (wlan0 or eth0) that connects your host machine to the Internet. | ||||
| 3. Set up a vagrant machine with `vagrant up` and provision it with `vagrant provision`.  Please select the available bridge network interface (wlan0 or eth0) that connects your host machine to the Internet. | ||||
| 
 | ||||
| 4. Connect to your vagrant machine with `vagrant ssh`. All your local development files available as shared folder in `/opt/iiab` directory. | ||||
| 4. Connect to your vagrant machine with `vagrant ssh`.  All your local development files available as shared folder in `/opt/iiab` directory. | ||||
| 
 | ||||
| 5. Install IIAB itself from the Ansible playbooks by following [IIAB Installation](https://github.com/iiab/iiab/wiki/IIAB-Installation#do-everything-from-scratch) instructions: | ||||
| ``` | ||||
|  | @ -82,11 +101,11 @@ This section provide a quick setup of Internet-in-a-Box (IIAB) development envir | |||
| ``` | ||||
| 6. Hack away! | ||||
| 
 | ||||
| 7. You can commit your local changes to your personal forks of Internet-in-a-Box repository and then send pull request to IIAB project. Once you forked a repository, you change directory into that repository and setting a default git remote push setting with the following command. | ||||
| 7. You can commit your local changes to your personal forks of Internet-in-a-Box repository and then send pull request to the IIAB project.  Once you've forked a repository, you change directory into that repository and set a default git remote push setting with the following command: | ||||
| 
 | ||||
|    `cd <repo> && git remote set-url --push origin git@github.com:<your_username>/<your_forked_iiab_repo_name>.git` | ||||
| 
 | ||||
| 	Learn more by reading blog post [Different git Push & Pull(fetch) URLs](http://blog.yuriy.tymch.uk/2012/05/different-git-push-pullfetch-urls.html) and the [Git Basics - Working with Remotes](https://git-scm.com/book/en/v2/Git-Basics-Working-with-Remotes) chapter of Scott Chacon and Ben Straub's "Git Pro" book. | ||||
| 	Learn more by reading the blog post [Different git Push & Pull(fetch) URLs](http://blog.yuriy.tymch.uk/2012/05/different-git-push-pullfetch-urls.html) and the [Git Basics - Working with Remotes](https://git-scm.com/book/en/v2/Git-Basics-Working-with-Remotes) chapter of Scott Chacon and Ben Straub's "Git Pro" book. | ||||
| 
 | ||||
| 8. Once you are done, you can stop your vagrant machine with `vagrant halt` or remove it completely with `vagrant destroy`. | ||||
| 
 | ||||
|  | @ -95,7 +114,7 @@ Debugging | |||
| 
 | ||||
| Here are few strategies for debugging problems during the Internet-in-a-Box installation. | ||||
| 
 | ||||
| * When a installation task fails, Ansible halts printing out a descriptive error message to the screen. This error information is also written to `iiab-install.log` file within `/opt/iiab/iiab`. (Look through logs to check if any preceding line contains the error). | ||||
| * When a installation task fails, Ansible halts printing out a descriptive error message to the screen. This error information is also written to `iiab-install.log` file within `/opt/iiab/iiab`.  (Look through logs to check if any preceding line contains the error). | ||||
| * When an installation succeeds, the last lines printed on the screen will look like the following (failed=0): | ||||
| ``` | ||||
|    PLAY RECAP ********************************************************************* | ||||
|  | @ -113,7 +132,7 @@ Testing your code with Travis CI | |||
| To maintain the quality of the Internet-in-a-Box (IIAB) code we use [Travis Continuous Integration (CI)](https://travis-ci.org) build infrastructure. Travis CI does tests to | ||||
| ensure the code syntax is correct and the code is formatted properly using `ansible` syntax checker, `ansible-lint` and `ansible-review` tools. The results of Travis CI Internet-in-a-Box (IIAB) could be seen [here](https://travis-ci.org/iiab/iiab). | ||||
| 
 | ||||
| Every pull request is automatically tested by Travis CI. The results of these tests are added to the pull request. This aids Internet-in-a-Box (IIAB) developers in reviewing the quality of the code in a pull request. | ||||
| Every pull request [was] automatically tested by Travis CI.  The results of these tests [were] added to the pull request.  This aids Internet-in-a-Box (IIAB) developers in reviewing the quality of the code in a pull request [this approach is currently on hold as of July 2018 — if it's tuned up this or any similar CI/CD alternatives would be welcome!] | ||||
| 
 | ||||
| To test your forked repository of Internet-in-a-Box (IIAB) code. You have to enable automatic build tests in your [Travis-ci.org](https://travis-ci.org) profile page. | ||||
| 
 | ||||
|  | @ -142,4 +161,4 @@ Get in touch | |||
| * Join our [live calls](http://minutes.iiab.io) most Mondays and Thursday | ||||
| * Join us on IRC live chat: [#schoolserver](https://webchat.freenode.net/?channels=#schoolserver) on [freenode]( https://www.freenode.net/) | ||||
| * Post an idea or question to our [community forums](http://iiab.io/) | ||||
| * Read our Frequently Asked Questions ([FAQ.IIAB.IO](http://FAQ.IIAB.IO)) | ||||
| * Read ["What are the best places for community support?"](http://FAQ.IIAB.IO#What_are_the_best_places_for_community_support.3F) within our Frequently Asked Questions  ([FAQ.IIAB.IO](http://FAQ.IIAB.IO)) | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ MIN_ANSIBLE_VER=2.5.6 | |||
| 
 | ||||
| export ANSIBLE_LOG_PATH="$CWD/iiab-install.log" | ||||
| 
 | ||||
| echo -e "\n\n./iiab-install BEGUN IN /opt/iiab/iiab\n" | ||||
| echo -e "\n\n./iiab-install $* BEGUN IN $CWD\n" | ||||
| 
 | ||||
| if [ ! -f /etc/ansible/facts.d/local_facts.fact ]; then | ||||
|     mkdir -p /etc/ansible/facts.d | ||||
|  | @ -145,4 +145,4 @@ echo -e "\nRunning local playbooks....Stage 0 will now run....followed by Stages | |||
| ansible -m setup -i $INVENTORY localhost --connection=local >> /dev/null | ||||
| ansible-playbook -i $INVENTORY $PLAYBOOK ${ARGS} --connection=local | ||||
| 
 | ||||
| echo -e "\n./iiab-install COMPLETED IN /opt/iiab/iiab\n\n" | ||||
| echo -e "./iiab-install $* COMPLETED IN $CWD\n\n" | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| elgg_xx: elgg | ||||
| elgg_version: "2.3.7" | ||||
| elgg_version: "2.3.8" | ||||
| 
 | ||||
| # elgg_mysql_password: defined in default_vars | ||||
| elgg_url: /elgg | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue