Compare commits
	
		
			9 Commits
		
	
	
		
			vapier
			...
			openrc-0.9
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 14b7f0e7fa | ||
|   | e45cd15930 | ||
|   | e4ce98b3b4 | ||
|   | 8a41537f68 | ||
|   | d8a5d35760 | ||
|   | cc8a9cdab9 | ||
|   | 04e6696782 | ||
|   | 85193674da | ||
|   | a73c26a70b | 
							
								
								
									
										15
									
								
								.cirrus.yml
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								.cirrus.yml
									
									
									
									
									
								
							| @@ -1,15 +0,0 @@ | |||||||
| # Cirrus CI integration |  | ||||||
| # https://cirrus-ci.org |  | ||||||
|  |  | ||||||
| test_task: |  | ||||||
|   freebsd_instance: |  | ||||||
|     matrix: |  | ||||||
|       image: freebsd-13-1-release-amd64 |  | ||||||
|       image: freebsd-12-4-release-amd64 |  | ||||||
|   env: |  | ||||||
|     OS: FreeBSD |  | ||||||
|   procfs_script: > |  | ||||||
|     [ -f /proc/curproc ] || mount -t procfs proc /proc |  | ||||||
|   pkg_install_script: pkg install -y bash gawk gsed meson |  | ||||||
|   gsed_hack_script: rm /usr/bin/sed && ln -s /usr/local/bin/gsed /usr/bin/sed |  | ||||||
|   test_script: bash ci/cirrus.sh |  | ||||||
							
								
								
									
										31
									
								
								.github/workflows/ci-alpine-linux.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/workflows/ci-alpine-linux.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,31 +0,0 @@ | |||||||
| name: ci_alpine_linux |  | ||||||
|  |  | ||||||
| on: [push, pull_request] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|  |  | ||||||
|   alpine: |  | ||||||
|     name: Alpine Linux |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     container: alpine:latest |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         compiler: |  | ||||||
|           - gcc |  | ||||||
|     env: |  | ||||||
|       CC: ${{ matrix.compiler }} |  | ||||||
|     steps: |  | ||||||
|       - run: >- |  | ||||||
|           apk --no-cache add \ |  | ||||||
|             build-base \ |  | ||||||
|             meson \ |  | ||||||
|             pkgconf \ |  | ||||||
|             linux-pam \ |  | ||||||
|             linux-pam-dev \ |  | ||||||
|             libcap \ |  | ||||||
|             libcap-dev |  | ||||||
|       - uses: actions/checkout@v2 |  | ||||||
|       - run: meson setup builddir/ |  | ||||||
|       - run: meson compile -C builddir |  | ||||||
|       - run: meson test --verbose -C builddir |  | ||||||
							
								
								
									
										24
									
								
								.github/workflows/ci-ubuntu.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/ci-ubuntu.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,24 +0,0 @@ | |||||||
| name: ci_ubuntu |  | ||||||
|  |  | ||||||
| on: [push, pull_request] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|  |  | ||||||
|   ubuntu: |  | ||||||
|     name: Ubuntu |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     strategy: |  | ||||||
|       fail-fast: false |  | ||||||
|       matrix: |  | ||||||
|         compiler: |  | ||||||
|           - gcc |  | ||||||
|           - clang |  | ||||||
|     env: |  | ||||||
|       CC: ${{ matrix.compiler }} |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v2 |  | ||||||
|     - run: sudo apt-get update -q |  | ||||||
|     - run: sudo apt-get install -q -y build-essential libpam-dev meson libcap-dev ${CC} |  | ||||||
|     - run: meson setup builddir/ |  | ||||||
|     - run: ninja -C builddir |  | ||||||
|     - run: ninja test --verbose -C builddir |  | ||||||
							
								
								
									
										25
									
								
								.github/workflows/coverity.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/coverity.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,25 +0,0 @@ | |||||||
| # GitHub actions workflow. |  | ||||||
| # https://docs.github.com/en/actions/learn-github-actions/workflow-syntax-for-github-actions |  | ||||||
|  |  | ||||||
| # https://scan.coverity.com/projects/openrc-openrc |  | ||||||
| name: Coverity Scan |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: [master] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   coverity: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v2 |  | ||||||
|     - run: sudo apt-get update -q |  | ||||||
|     - run: sudo apt-get install -q -y build-essential libpam-dev meson libcap-dev |  | ||||||
|     - run: meson setup builddir/ |  | ||||||
|       env: |  | ||||||
|         CC: gcc |  | ||||||
|     - uses: vapier/coverity-scan-action@v1 |  | ||||||
|       with: |  | ||||||
|         command: ninja -C builddir |  | ||||||
|         email: ${{ secrets.COVERITY_SCAN_EMAIL }} |  | ||||||
|         token: ${{ secrets.COVERITY_SCAN_TOKEN }} |  | ||||||
							
								
								
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| *.gz | *.bz2 | ||||||
|  |  | ||||||
| *.diff | *.diff | ||||||
| *.patch | *.patch | ||||||
| @@ -9,4 +9,8 @@ core | |||||||
| .gdb_history | .gdb_history | ||||||
| .gdbinit | .gdbinit | ||||||
|  |  | ||||||
| build | .depend | ||||||
|  | *.a | ||||||
|  | *.o | ||||||
|  | *.So | ||||||
|  | lib*.so | ||||||
|   | |||||||
							
								
								
									
										32
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								.travis.yml
									
									
									
									
									
								
							| @@ -1,32 +0,0 @@ | |||||||
| # Travis build integration. |  | ||||||
| # https://docs.travis-ci.com/ |  | ||||||
|  |  | ||||||
| language: c |  | ||||||
|  |  | ||||||
| os: |  | ||||||
|   - linux |  | ||||||
|  |  | ||||||
| compiler: |  | ||||||
|   - gcc |  | ||||||
|   - clang |  | ||||||
|   - musl-gcc |  | ||||||
|  |  | ||||||
| addons: |  | ||||||
|   apt: |  | ||||||
|     packages: |  | ||||||
|     - musl-tools |  | ||||||
|  |  | ||||||
| notifications: |  | ||||||
|   irc: |  | ||||||
|     channels: |  | ||||||
|       - "irc.libera.chat#openrc" |  | ||||||
|     on_success: always  # options: [always|never|change] default: always |  | ||||||
|     on_failure: always  # options: [always|never|change] default: always |  | ||||||
|     on_start: false     # default: false |  | ||||||
|  |  | ||||||
| before_install: |  | ||||||
|   - sudo apt-get update |  | ||||||
|   - sudo apt-get install -y shellcheck |  | ||||||
|  |  | ||||||
| script: |  | ||||||
|   - ./ci/travis.sh |  | ||||||
							
								
								
									
										101
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										101
									
								
								AUTHORS
									
									
									
									
									
								
							| @@ -1,101 +0,0 @@ | |||||||
| Alessio Ababilov <ilovedevlinux@gmail.com> |  | ||||||
| Alexander Berntsen <alexander@plaimi.net> |  | ||||||
| Alexander Mezin <mezin.alexander@gmail.com> |  | ||||||
| Alexander Tsoy <alexander@tsoy.me> |  | ||||||
| Alexander Vershilov <alexander.vershilov@gmail.com> |  | ||||||
| Alexander Vershilov <qnikst@gentoo.org> |  | ||||||
| Alexander V Vershilov <qnikst@gentoo.org> |  | ||||||
| Alexey Shvetsov <alexxy@gentoo.org> |  | ||||||
| Alon Bar-Lev <alon.barlev@gmail.com> |  | ||||||
| Amadeusz Żołnowski <aidecoe@aidecoe.name> |  | ||||||
| Andrew Gregory <andrew.gregory.8@gmail.com> |  | ||||||
| Anthony Donnelly <Amzo@archbsd.com> |  | ||||||
| Anthony G. Basile <basile@opensource.dyc.edu> |  | ||||||
| Anthony G. Basile <blueness@gentoo.org> |  | ||||||
| Austin S. Hemmelgarn <ahferroin7@gmail.com> |  | ||||||
| Benda Xu <heroxbd@gentoo.org> |  | ||||||
| Björn Baumbach <bb@sernet.de> |  | ||||||
| Charlie <root@uberlaptop.development.ltl> |  | ||||||
| Chris Richards <gizmo@giz-works.com> |  | ||||||
| Christian <christian@ch-sc.de> |  | ||||||
| Christian Ruppert <idl0r@gentoo.org> |  | ||||||
| Christian Wetzig <gentoo@wetzig.de> |  | ||||||
| Christopher Head <chead@telus.net> |  | ||||||
| Consus <consus@gmx.com> |  | ||||||
| Daniel Mierswa <impulze@impulze.org> |  | ||||||
| Daniel Robbins <drobbins@funtoo.org> |  | ||||||
| Diego Elio Pettenò <flameeyes@flameeyes.eu> |  | ||||||
| Diego Elio Pettenò <flameeyes@gmail.com> |  | ||||||
| Diego <flameeyes@gentoo.org> |  | ||||||
| Dirk Sondermann <ds-gentoo@dyximaq.de> |  | ||||||
| Doug Freed <dwfreed@mtu.edu> |  | ||||||
| Doug Goldstein <cardoe@cardoe.com> |  | ||||||
| Ed Wildgoose <gentoo@wildgooses.com> |  | ||||||
| Eray Aslan <eras@gentoo.org> |  | ||||||
| Eugeny Shkrigunov <eshkrig@gmail.com> |  | ||||||
| Fedja Beader <specing@contact.me.on.irc.freenode.net> |  | ||||||
| Flex <frostynova@gmail.com> |  | ||||||
| Gabriele Giacone <1o5g4r8o@gmail.com> |  | ||||||
| Gary <admin@garyshood.com> |  | ||||||
| Gilles Oivier <g.olivier@wanadoo.fr> |  | ||||||
| Hank Leininger <hlein@korelogic.com> |  | ||||||
| Ian Stakenvicius <axs@gentoo.org> |  | ||||||
| Jakob Drexel <jake42@rommel.stw.uni-erlangen.de> |  | ||||||
| James Le Cuirot <chewi@aura-online.co.uk> |  | ||||||
| Jan Psota <jasiu@belsznica.pl> |  | ||||||
| Jason A. Donenfeld <Jason@zx2c4.com> |  | ||||||
| Jason Zaman <jason@perfinion.com> |  | ||||||
| Joe Harvell <jharvell@dogpad.net> |  | ||||||
| Joe M <joe9mail@gmail.com> |  | ||||||
| Johan Bergström <bugs@bergstroem.nu> |  | ||||||
| Jory A. Pratt <anarchy@gentoo.org> |  | ||||||
| Juan RP <xtraeme@gmail.com> |  | ||||||
| Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi> |  | ||||||
| Kfir Lavi <lavi.kfir@gmail.com> |  | ||||||
| Kirill Elagin <kirelagin@gmail.com> |  | ||||||
| Lars Wendler <polynomial-c@gentoo.org> |  | ||||||
| Lorand Kelemen <lorand.kelemen@indgroup.eu> |  | ||||||
| Marc Joliet <marcec@gmx.de> |  | ||||||
| Marien Zwart <marienz@gentoo.org> |  | ||||||
| Michal Gorny <gentoo@mgorny.alt.pl> |  | ||||||
| Mihai Moldovan <ionic@ionic.de> |  | ||||||
| Mike Frysinger <vapier@gentoo.org> |  | ||||||
| Mike Gilbert <floppym@gentoo.org> |  | ||||||
| Nao Nakashima <nao.nakashima@gmail.com> |  | ||||||
| Natanael Copa <natanael.copa@gmail.com> |  | ||||||
| Nathan Phillip Brink <ohnobinki@ohnopublishing.net> |  | ||||||
| Ned Ludd <solar@gentoo.org> |  | ||||||
| Olivier Huber <oli.huber@gmail.com> |  | ||||||
| Patrick Lauer <patrick@gentoo.org> |  | ||||||
| Petre Rodan <petre.rodan@simplex.ro> |  | ||||||
| Piotr Karbowski <piotr.karbowski@gmail.com> |  | ||||||
| Ralph Sennhauser <sera@gentoo.org> |  | ||||||
| Richard Yao <ryao@cs.stonybrook.edu> |  | ||||||
| Rick Farina (ZeroChaos) <sidhayn@gmail.com> |  | ||||||
| Rick Farina (Zero_Chaos) <zerochaos@gentoo.org> |  | ||||||
| Robin H. Johnson <robbat2@gentoo.org> |  | ||||||
| Robin H. Johnson <robbat2@orbis-terrarum.net> |  | ||||||
| Robin Johnson <robbat2@gentoo.org> |  | ||||||
| Roy Marples <roy@marples.name> |  | ||||||
| Salah Coronya <salah.coronya@gmail.com> |  | ||||||
| Sebastian Thorarensen <indigo176@blinkenshell.org> |  | ||||||
| Semen Maryasin <marsoft@ya.ru> |  | ||||||
| Sergei Trofimovich <slyfox@gentoo.org> |  | ||||||
| Seth Robertson <in-gentoo@baka.org> |  | ||||||
| S. Gilles <sgilles@umd.edu> |  | ||||||
| Sony Interactive Entertainment, llc. |  | ||||||
| Stefan Knoblich <s.knoblich@axsentis.de> |  | ||||||
| Stef Simoens <stef.simoens@scarlet.be> |  | ||||||
| Steve L <slong@rathaus.eclipse.co.uk> |  | ||||||
| Steven Chamberlain <steven@pyro.eu.org> |  | ||||||
| Svante Signell <svante.signell@gmail.com> |  | ||||||
| Sven Vermeulen <sven.vermeulen@siphos.be> |  | ||||||
| Thomas D <whissi@whissi.de> |  | ||||||
| Thomas Pfaff <tpfaff@gmx.net> |  | ||||||
| Trevor Summers Smith <trevorsummerssmith@gmail.com> |  | ||||||
| Walter <walter@pratyeka.org> |  | ||||||
| William Hubbs <w.d.hubbs@gmail.com> |  | ||||||
| William Hubbs <williamh@gentoo.org> |  | ||||||
| Will Miles <wmiles@sgl.com> |  | ||||||
| Yun Zheng Hu <hu@fox-it.com> |  | ||||||
| Yuta SATOH <nigoro.gentoo@0x100.com> |  | ||||||
							
								
								
									
										30
									
								
								BUSYBOX.md
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								BUSYBOX.md
									
									
									
									
									
								
							| @@ -1,30 +0,0 @@ | |||||||
| Using Busybox as your Default Shell with OpenRC |  | ||||||
| =============================================== |  | ||||||
|  |  | ||||||
| If you have/bin/sh linked to busybox, you need to be aware of several |  | ||||||
| incompatibilities between busybox's applets and the standalone |  | ||||||
| counterparts. Since it is possible to configure busybox to not include |  | ||||||
| these applets or to prefer the standalone counterparts, OpenRC does not |  | ||||||
| attempt to support the busybox applets. |  | ||||||
|  |  | ||||||
| For now, it is recommended that you disable the following busybox |  | ||||||
| configuration settings for best results with OpenRC. |  | ||||||
|  |  | ||||||
| CONFIG_START_STOP_DAEMON -- The start-stop-daemon applet is not compatible with |  | ||||||
| start-stop-daemon in OpenRC. |  | ||||||
|  |  | ||||||
| CONFIG_MOUNT -- The mount applet does not support the -O [no]_netdev options to |  | ||||||
| skip over or include network file systems when the -a option is present. |  | ||||||
|  |  | ||||||
| CONFIG_UMOUNT -- The umount applet does not support the -O option along with -a. |  | ||||||
|  |  | ||||||
| CONFIG_SWAPONOFF -- The swapon applet does not support the -e option |  | ||||||
| or recognize the nofail option in fstab. |  | ||||||
|  |  | ||||||
| CONFIG_SETFONT -- The setfont applet does not support the -u option from kbd. |  | ||||||
|  |  | ||||||
| CONFIG_BB_SYSCTL -- The sysctl applet does not support the --system command |  | ||||||
| line switch. |  | ||||||
|  |  | ||||||
| There is work to get most of these supported by busybox, so this file |  | ||||||
| will be updated as things change. |  | ||||||
| @@ -1,142 +0,0 @@ | |||||||
| # OpenRC Code of Conduct |  | ||||||
|  |  | ||||||
| This code of conduct outlines our expectations for participants within the |  | ||||||
| community, as well as steps for reporting unacceptable behavior. We are |  | ||||||
| committed to providing a welcoming and inspiring community for all and |  | ||||||
| expect our code of conduct to be honored. Anyone who violates this code |  | ||||||
| of conduct may be banned from the community. |  | ||||||
|  |  | ||||||
| ## Our Pledge |  | ||||||
|  |  | ||||||
| We as members, contributors, and leaders pledge to make participation in our |  | ||||||
| community a harassment-free experience for everyone, regardless of age, body |  | ||||||
| size, visible or invisible disability, ethnicity, sex characteristics, gender |  | ||||||
| identity and expression, level of experience, education, socio-economic status, |  | ||||||
| nationality, personal appearance, race, caste, color, religion, or sexual |  | ||||||
| identity and orientation. |  | ||||||
|  |  | ||||||
| We pledge to act and interact in ways that contribute to an open, welcoming, |  | ||||||
| diverse, inclusive, and healthy community. |  | ||||||
|  |  | ||||||
| ## Our Standards |  | ||||||
|  |  | ||||||
| Examples of behavior that contributes to a positive environment for our |  | ||||||
| community include: |  | ||||||
|  |  | ||||||
| * Demonstrating empathy and kindness toward other people |  | ||||||
| * Being respectful of differing opinions, viewpoints, and experiences |  | ||||||
| * Giving and gracefully accepting constructive feedback |  | ||||||
| * Accepting responsibility and apologizing to those affected by our mistakes, |  | ||||||
|   and learning from the experience |  | ||||||
| * Focusing on what is best not just for us as individuals, but for the overall |  | ||||||
|   community |  | ||||||
|  |  | ||||||
| Examples of unacceptable behavior include: |  | ||||||
|  |  | ||||||
| * The use of sexualized language or imagery, and sexual attention or advances of |  | ||||||
|   any kind |  | ||||||
| * Trolling, insulting or derogatory comments, and personal or political attacks |  | ||||||
| * Public or private harassment |  | ||||||
| * Publishing others' private information, such as a physical or email address, |  | ||||||
|   without their explicit permission |  | ||||||
| * Other conduct which could reasonably be considered inappropriate in a |  | ||||||
|   professional setting |  | ||||||
|  |  | ||||||
| ## Enforcement Responsibilities |  | ||||||
|  |  | ||||||
| Community leaders are responsible for clarifying and enforcing our standards of |  | ||||||
| acceptable behavior and will take appropriate and fair corrective action in |  | ||||||
| response to any behavior that they deem inappropriate, threatening, offensive, |  | ||||||
| or harmful. |  | ||||||
|  |  | ||||||
| Community leaders have the right and responsibility to remove, edit, or reject |  | ||||||
| comments, commits, code, wiki edits, issues, and other contributions that are |  | ||||||
| not aligned to this Code of Conduct, and will communicate reasons for moderation |  | ||||||
| decisions when appropriate. |  | ||||||
|  |  | ||||||
| ## Scope |  | ||||||
|  |  | ||||||
| This Code of Conduct applies within all community spaces, and also applies when |  | ||||||
| an individual is officially representing the community in public spaces. |  | ||||||
| Examples of representing our community include using an official e-mail address, |  | ||||||
| posting via an official social media account, or acting as an appointed |  | ||||||
| representative at an online or offline event. |  | ||||||
|  |  | ||||||
| ## Enforcement |  | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be |  | ||||||
| reported to the community leaders responsible for enforcement via integrated |  | ||||||
| "Report Content" functionality. |  | ||||||
| See the GitHub documentation for more details: |  | ||||||
| https://docs.github.com/en/communities/maintaining-your-safety-on-github/reporting-abuse-or-spam |  | ||||||
|  |  | ||||||
| All complaints will be reviewed and investigated promptly and fairly. |  | ||||||
|  |  | ||||||
| All community leaders are obligated to respect the privacy and security of the |  | ||||||
| reporter of any incident. |  | ||||||
|  |  | ||||||
| ## Enforcement Guidelines |  | ||||||
|  |  | ||||||
| Community leaders will follow these Community Impact Guidelines in determining |  | ||||||
| the consequences for any action they deem in violation of this Code of Conduct: |  | ||||||
|  |  | ||||||
| ### 1. Correction |  | ||||||
|  |  | ||||||
| **Community Impact**: Use of inappropriate language or other behavior deemed |  | ||||||
| unprofessional or unwelcome in the community. |  | ||||||
|  |  | ||||||
| **Consequence**: A private, written warning from community leaders, providing |  | ||||||
| clarity around the nature of the violation and an explanation of why the |  | ||||||
| behavior was inappropriate. A public apology may be requested. |  | ||||||
|  |  | ||||||
| ### 2. Warning |  | ||||||
|  |  | ||||||
| **Community Impact**: A violation through a single incident or series of |  | ||||||
| actions. |  | ||||||
|  |  | ||||||
| **Consequence**: A warning with consequences for continued behavior. No |  | ||||||
| interaction with the people involved, including unsolicited interaction with |  | ||||||
| those enforcing the Code of Conduct, for a specified period of time. This |  | ||||||
| includes avoiding interactions in community spaces as well as external channels |  | ||||||
| like social media. Violating these terms may lead to a temporary or permanent |  | ||||||
| ban. |  | ||||||
|  |  | ||||||
| ### 3. Temporary Ban |  | ||||||
|  |  | ||||||
| **Community Impact**: A serious violation of community standards, including |  | ||||||
| sustained inappropriate behavior. |  | ||||||
|  |  | ||||||
| **Consequence**: A temporary ban from any sort of interaction or public |  | ||||||
| communication with the community for a specified period of time. No public or |  | ||||||
| private interaction with the people involved, including unsolicited interaction |  | ||||||
| with those enforcing the Code of Conduct, is allowed during this period. |  | ||||||
| Violating these terms may lead to a permanent ban. |  | ||||||
|  |  | ||||||
| ### 4. Permanent Ban |  | ||||||
|  |  | ||||||
| **Community Impact**: Demonstrating a pattern of violation of community |  | ||||||
| standards, including sustained inappropriate behavior, harassment of an |  | ||||||
| individual, or aggression toward or disparagement of classes of individuals. |  | ||||||
|  |  | ||||||
| **Consequence**: A permanent ban from any sort of public interaction within the |  | ||||||
| community. |  | ||||||
|  |  | ||||||
| ## Attribution |  | ||||||
|  |  | ||||||
| This Code of Conduct is adapted from the [Contributor Covenant][homepage], |  | ||||||
| version 2.1, available at |  | ||||||
| [https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1]. |  | ||||||
|  |  | ||||||
| Community Impact Guidelines were inspired by |  | ||||||
| [Mozilla's code of conduct enforcement ladder][Mozilla CoC]. |  | ||||||
|  |  | ||||||
| For answers to common questions about this code of conduct, see the FAQ at |  | ||||||
| [https://www.contributor-covenant.org/faq][FAQ]. Translations are available at |  | ||||||
| [https://www.contributor-covenant.org/translations][translations]. |  | ||||||
|  |  | ||||||
| [homepage]: https://www.contributor-covenant.org |  | ||||||
| [v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html |  | ||||||
| [Mozilla CoC]: https://github.com/mozilla/diversity |  | ||||||
| [FAQ]: https://www.contributor-covenant.org/faq |  | ||||||
| [translations]: https://www.contributor-covenant.org/translations |  | ||||||
|  |  | ||||||
							
								
								
									
										49
									
								
								FEATURE-REMOVAL-SCHEDULE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								FEATURE-REMOVAL-SCHEDULE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | |||||||
|  | The following is a list of files and features that are going to be removed in | ||||||
|  | the source tree.  Every entry should contain what exactly is going away, why it | ||||||
|  | is happening, and who is going to be doing the work.  When the feature is | ||||||
|  | removed, it should also be removed from this file. | ||||||
|  |  | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | What: oldnet ADSL rp-pppoe mode | ||||||
|  |  | ||||||
|  | When: undecided | ||||||
|  |  | ||||||
|  | Why: Replaced by the oldnet PPP module | ||||||
|  |  | ||||||
|  | Who:  Robin H. Johnson <robbat2@gentoo.org> | ||||||
|  |  | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | What: oldnet /etc/conf.d/wireless | ||||||
|  |  | ||||||
|  | When: undecided | ||||||
|  |  | ||||||
|  | Why: All configuration moved to /etc/conf.d/net | ||||||
|  |  | ||||||
|  | Who:  Robin H. Johnson <robbat2@gentoo.org> | ||||||
|  |  | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | What: Service pause action | ||||||
|  |  | ||||||
|  | When: Removed already, compatbility warning in place. | ||||||
|  |  | ||||||
|  | Why: ... | ||||||
|  |  | ||||||
|  | Who: | ||||||
|  |  | ||||||
|  | --------------------------- | ||||||
|  |  | ||||||
|  | What: Service --startas, --chuid , --oknodo | ||||||
|  |  | ||||||
|  | When: undecided | ||||||
|  |  | ||||||
|  | Why: Obsolete or replaced by other options. | ||||||
|  | 	 --startas => use --name or --exec | ||||||
|  | 	 --chuid => use --user | ||||||
|  | 	 --oknodo => ignore return code instead | ||||||
|  |  | ||||||
|  | Who: | ||||||
|  |  | ||||||
|  | --------------------------- | ||||||
| @@ -1,79 +0,0 @@ | |||||||
| Features Scheduled for Removal |  | ||||||
| ============================== |  | ||||||
|  |  | ||||||
| The following is a list of files and features that are going to be removed in |  | ||||||
| the source tree.  Every entry should contain what exactly is going away, why it |  | ||||||
| is happening, and who is going to be doing the work.  When the feature is |  | ||||||
| removed, it should also be removed from this file. |  | ||||||
|  |  | ||||||
| # Service pause action |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: The same affect can be obtained with the --nodeps option to stop. |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # start-stop-daemon options --startas, --chuid , --oknodo |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: Obsolete or replaced by other options. |  | ||||||
|  |  | ||||||
| * --startas => use --name or --exec |  | ||||||
| * --chuid => use --user |  | ||||||
| * --oknodo => ignore return code instead |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # runscript and rc symbolic links |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: Deprecated in favor of openrc-run and openrc due to naming |  | ||||||
| 	 conflicts with other software. |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # support for the opts variable in service scripts |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: Deprecated in favor of extra_commands, extra_started_commands |  | ||||||
| 	 and extra_stopped_commands. |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # support for local_start and local_stop |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: Deprecated in favor of executable scripts in @SYSCONFDIR@/local.d |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # the mtab service script |  | ||||||
|  |  | ||||||
| When: force /etc/mtab to link to /proc/self/mounts in 1.0, remove |  | ||||||
| 	  service in 2.0 |  | ||||||
|  |  | ||||||
| Why: /etc/mtab should be a symbolic link to /proc/self/mounts on modern |  | ||||||
| 	 Linux systems |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
| # C API Functions in rc.h |  | ||||||
|  |  | ||||||
| If you have a c program that links to librc and uses functions from |  | ||||||
| there, this section will list API functions which are deprecated and |  | ||||||
| will be removed along with the reason they are being removed. |  | ||||||
|  |  | ||||||
| ## rc_getline() |  | ||||||
|  |  | ||||||
| When: 1.0 |  | ||||||
|  |  | ||||||
| Why: The getline() function was standardized in POSIX.1-2008, so it |  | ||||||
| 	 should be available on POSIX systems. |  | ||||||
|  |  | ||||||
| Who: |  | ||||||
|  |  | ||||||
							
								
								
									
										63
									
								
								HISTORY.md
									
									
									
									
									
								
							
							
						
						
									
										63
									
								
								HISTORY.md
									
									
									
									
									
								
							| @@ -1,63 +0,0 @@ | |||||||
| OpenRC History |  | ||||||
| ============== |  | ||||||
|  |  | ||||||
| This history of OpenRC was written by Daniel Robbins, Roy Marples, William |  | ||||||
| Hubbs and others. |  | ||||||
|  |  | ||||||
| The Gentoo modular init scripts were developed by Daniel Robbins for Gentoo |  | ||||||
| Linux 1.0_rc6 during most of 2001 and released in September 2001. After their |  | ||||||
| development, the dependency-based init script system was maintained by a |  | ||||||
| number of senior developers, starting with Azarah (Martin Schlemmer), with |  | ||||||
| migration to the new init system assisted by Woodchip (Donnie Davies) who |  | ||||||
| converted all ebuild init scripts to work with the new system. As Grant |  | ||||||
| Goodyear notes:  |  | ||||||
|  |  | ||||||
| "My recollection is that one of woodchip's more impressive early feats |  | ||||||
| was the complete replacement of all of the init scripts in Portage |  | ||||||
| for Gentoo Linux 1.0_rc6. Through 1.0_rc5 Gentoo had used fairly |  | ||||||
| standard rc scripts modified from Stampede Linux, but for 1.0_rc6 Daniel |  | ||||||
| Robbins (drobbins) and Martin Schlemmer (azarah) had created a new |  | ||||||
| dependency-based init script system that is still used today. Within a |  | ||||||
| span of days Donny rewrote every single init script in the Portage tree |  | ||||||
| and committed new masked packages to await the release of 1.0_rc6. Thanks to |  | ||||||
| woodchip (and drobbins and azarah, of course) the |  | ||||||
| transition to the new init scripts was nearly painless." [1]  |  | ||||||
|  |  | ||||||
| Roy Marples became a Gentoo/Linux developer in 2004 and wrote the modular |  | ||||||
| network scripts for the Gentoo baselayout package. Towards the end of 2005, |  | ||||||
| he became the primary maintainer for baselayout and the init scripts.  |  | ||||||
|  |  | ||||||
| At the start of 2007, He announced the ongoing development of |  | ||||||
| baselayout-2, containing a rewritten core coded in C and allowing POSIX sh |  | ||||||
| init scripts instead of forcing the use of bash. By mid 2007, He had |  | ||||||
| re-implemented the Gentoo init script design created by Daniel Robbins, |  | ||||||
| using an entirely new code base. Alpha and pre-release baselayout-2 |  | ||||||
| snapshots were added to Gentoo's Portage tree as an optional component. |  | ||||||
|  |  | ||||||
| Toward the end of 2007, Roy retired as a Gentoo developer. |  | ||||||
| Baselayout-2 was still in the pre stage, and aside from the gentoo-fbsd |  | ||||||
| users, it was masked. However, He desired to keep the baselayout-2 |  | ||||||
| project moving forward as an independent project. The Gentoo Council |  | ||||||
| permitted Him to release OpenRC under the 2-clause BSD license, |  | ||||||
| managed by him as an external project.  |  | ||||||
|  |  | ||||||
| Around mid-2010, Roy decided to no longer maintain OpenRC. At this |  | ||||||
| point, he transferred development back to Gentoo. |  | ||||||
|  |  | ||||||
| William Hubbs, and several other Gentoo developers,  started working on |  | ||||||
| OpenRC around this point and brought OpenRC-0.8.x to Gentoo Linux's stable |  | ||||||
| tree in 2011. |  | ||||||
|  |  | ||||||
| In 2013 the OpenRC team became independent from Gentoo again and moved primary |  | ||||||
| development to github. |  | ||||||
|  |  | ||||||
| Daniel Robbins continues to maintain an independent, forked |  | ||||||
| version of OpenRC for Funtoo Linux, which includes a Funtoo-specific network |  | ||||||
| configuration system.  |  | ||||||
|  |  | ||||||
| On 17-Dec-2015 utc, Roy gave the OpenRC developers permission to replace his |  | ||||||
| copyrights in all source files with a generic Copyright assertion for |  | ||||||
| the OpenRC developers as long as we keep the original copyright in the |  | ||||||
| binaries and  LICENSE file. |  | ||||||
|  |  | ||||||
| [1] http://www.gentoo.org/news/en/gwn/20040426-newsletter.xml |  | ||||||
							
								
								
									
										24
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -1,24 +0,0 @@ | |||||||
| Copyright (c) 2007-2008, Roy Marples <roy@marples.name> |  | ||||||
| Copyright (c) 2007-2023, the OpenRC authors |  | ||||||
| All rights reserved. |  | ||||||
|  |  | ||||||
| Redistribution and use in source and binary forms, with or without |  | ||||||
| modification, are permitted provided that the following conditions are met: |  | ||||||
|  |  | ||||||
| 1. Redistributions of source code must retain the above copyright notice, |  | ||||||
|    this list of conditions and the following disclaimer. |  | ||||||
| 2. 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. |  | ||||||
							
								
								
									
										30
									
								
								Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | # OpenRC Makefile | ||||||
|  | # Copyright (c) 2007-2009 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | include Makefile.inc | ||||||
|  |  | ||||||
|  | SUBDIR=		conf.d doc etc init.d local.d man net scripts sh src | ||||||
|  |  | ||||||
|  | # Build pkgconfig or not | ||||||
|  | MKPKGCONFIG?=	yes | ||||||
|  | ifeq (${MKPKGCONFIG},yes) | ||||||
|  | SUBDIR+=	pkgconfig | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # We need to ensure that runlevels is done last | ||||||
|  | SUBDIR+=	runlevels | ||||||
|  |  | ||||||
|  | INSTALLAFTER=	_installafter | ||||||
|  |  | ||||||
|  | MK= 		mk | ||||||
|  | include ${MK}/sys.mk | ||||||
|  | include ${MK}/os.mk | ||||||
|  | include ${MK}/subdir.mk | ||||||
|  | include ${MK}/dist.mk | ||||||
|  | include ${MK}/git.mk | ||||||
|  |  | ||||||
|  | _installafter: | ||||||
|  | 	${INSTALL} -d ${DESTDIR}/${LIBEXECDIR}/init.d | ||||||
|  | 	${INSTALL} -d ${DESTDIR}/${LIBEXECDIR}/tmp | ||||||
|  | 	${ECHO} "${VERSION}${GITVER}" > ${DESTDIR}/${LIBEXECDIR}/version | ||||||
							
								
								
									
										3
									
								
								Makefile.inc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								Makefile.inc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | NAME=		openrc | ||||||
|  | VERSION=	0.9.8.4 | ||||||
|  | PKG=		${NAME}-${VERSION} | ||||||
							
								
								
									
										36
									
								
								NEWNET.md
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								NEWNET.md
									
									
									
									
									
								
							| @@ -1,36 +0,0 @@ | |||||||
| OpenRC Network Ideals |  | ||||||
| ===================== |  | ||||||
|  |  | ||||||
| The new style networking for OpenRC is very simplistic - provide a basic means |  | ||||||
| of configuring static interface address and routes whilst allowing the |  | ||||||
| possibility to run any command at any point. |  | ||||||
|  |  | ||||||
| In a nutshell, init.d/network is a wrapper around ifconfig(8) and |  | ||||||
| init.d/staticroute is wrapper around route(8). |  | ||||||
|  |  | ||||||
| In the Perfect World (TM) ifconfig should be able to configure everything |  | ||||||
| about the interface easily * . The BSD family almost get this right and Linux |  | ||||||
| epically fails. |  | ||||||
|  |  | ||||||
| * Only static configuration, including link setup. |  | ||||||
| For dynamic, static, IPv4LL, arping and per ssid IPv4 setup dhcpcd-5.x |  | ||||||
| provides your needs. |  | ||||||
|  |  | ||||||
| It fails because there are many tools to do the same job and often have |  | ||||||
| vastly different syntax where they could be similar. In other words, there |  | ||||||
| is no coherence. |  | ||||||
|  |  | ||||||
| OpenRC-0.4.x and older (inc Gentoo baselayout-1) had a collection of scripts |  | ||||||
| for each tool and allowed a script per interface. Over the years, this design |  | ||||||
| has proven very hard to maintain as each user has their own idea of how |  | ||||||
| things should work. Also, there were (and still are) race conditions. |  | ||||||
|  |  | ||||||
| So where do we go from here? |  | ||||||
| Well, it's possible to use the new network scripts using the tools |  | ||||||
| currently available. It's just harder as you have to know them and their |  | ||||||
| documentation can be lacking at times. |  | ||||||
| The correct end goal is a BSD style ifconfig tool. |  | ||||||
| I've started work on it, but the project has stalled somewhat. |  | ||||||
| It's display only right now and the source is not yet publicly available. |  | ||||||
| If you have the skills and share the vision then contact me privately and |  | ||||||
| we'll take it from there. |  | ||||||
							
								
								
									
										413
									
								
								NEWS.md
									
									
									
									
									
								
							
							
						
						
									
										413
									
								
								NEWS.md
									
									
									
									
									
								
							| @@ -1,413 +0,0 @@ | |||||||
| OpenRC NEWS |  | ||||||
| =========== |  | ||||||
|  |  | ||||||
| This file will contain a list of notable changes for each release. Note |  | ||||||
| the information in this file is in reverse order. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.46 |  | ||||||
|  |  | ||||||
| The path for the reference file for the swclock service is now |  | ||||||
| configurable in conf.d/swclock. |  | ||||||
|  |  | ||||||
| In the past, if supervise_daemon_args was not set *or empty*, it defaulted to |  | ||||||
| `start_stop_daemon_args`. This was bad because supervise-daemon doesn't |  | ||||||
| accept the same options as `start-stop-daemon`. So if we set e.g. |  | ||||||
| `start_stop_daemon_args="--wait 50"`, but not `supervise_daemon_args`, |  | ||||||
| and the user adds `supervisor=supervise-daemon` to the corresponding |  | ||||||
| conf.d/<service> file, the service will fail to start due to |  | ||||||
| unrecognized option "wait". |  | ||||||
| It would be best to remove this fallback, but that might break some |  | ||||||
| existing scripts that depend on it. So we are changing it to |  | ||||||
| use `start_stop_daemon_args` as the default for `supervise_daemon_args` |  | ||||||
| only if `supervise_daemon_args` is not set at all, but not if it's |  | ||||||
| empty. |  | ||||||
|  |  | ||||||
| This fallback will be dropped in a future release. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## OpenRC 0.45 |  | ||||||
|  |  | ||||||
| The old make-based build system is removed in this release. |  | ||||||
|  |  | ||||||
| The killprocs service now has a KILL_DELAY setting to allow OpenRC based |  | ||||||
| containers to close all TCP/IP connections before they are shut down. |  | ||||||
|  |  | ||||||
| The --oom-score-adj option has been added to start-stop-daemon and |  | ||||||
| supervise-daemon. This sets the appropriate setting for the Linux |  | ||||||
| kernel. for more info, see the man pages. |  | ||||||
|  |  | ||||||
| Support for Linux capabilities has been added to both supervise-daemon |  | ||||||
| and start-stop-daemon using the --capabilities option. |  | ||||||
| As a result, the user can specify the inheritable, ambient and bounding set |  | ||||||
| by defining capabilities in the service script. |  | ||||||
|  |  | ||||||
| noexec has been added to the default mount options for /dev. If you need |  | ||||||
| to remove this option, add an entry to fstab. |  | ||||||
|  |  | ||||||
| A --secbits option has been added to start-stop-daemon and |  | ||||||
| supervise-daemon. This sets the security bits option which should be |  | ||||||
| applied to the daemon. |  | ||||||
|  |  | ||||||
| A no-new-privs option has been added to start-stop-daemon and |  | ||||||
| supervise-daemon. This sets the NO_NEW_PRIVS flag to apply to the |  | ||||||
| daemon. |  | ||||||
|  |  | ||||||
| On Linux, the service that seeds the random number generator has been |  | ||||||
| renamed from urandom to seedrng. This means that when  you upgrade to |  | ||||||
| this version, if urandom is in your boot runlevel, you must add seedrng. |  | ||||||
| This can be done by issuing the following commands: |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| # rc-update add seedrng boot |  | ||||||
| # rc-update del urandom boot |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## OpenRC 0.44 |  | ||||||
|  |  | ||||||
| This version is the first to use a meson-based build system. |  | ||||||
| The gnu make build system should now be considered deprecated; it will |  | ||||||
| be removed sometime after 0.44.x. |  | ||||||
|  |  | ||||||
| I have opened a [discussion](https://github.com/OpenRC/openrc/discussions/441) |  | ||||||
| where you can voice concerns about removing it. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.43 |  | ||||||
|  |  | ||||||
| This version changes the behavior of the checkpath helper to address |  | ||||||
| CVE-2018-21269. on Linux systems, We require  non-terminal symbolic links |  | ||||||
| to be owned by root. Since we can't do this on non-linux systems, we do |  | ||||||
| not dereference non-terminal symbolic links by default. If you need them |  | ||||||
| dereferenced, you should add the "-s" switch to the appropriate |  | ||||||
| checkpath calls. |  | ||||||
| For more information, see http://github.com/openrc/openrc/issues/201. |  | ||||||
|  |  | ||||||
| The SHLIBDIR variable has been removed from the makefiles to make them |  | ||||||
| more consistent with most common makefiles. All libraries are now in |  | ||||||
| LIBDIR, so if you need to put them in /, override the LIBDIR variable |  | ||||||
| when you run make. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.42 |  | ||||||
|  |  | ||||||
| openrc-shutdown now has the ability to shut down sysvinit-based systems. |  | ||||||
|  |  | ||||||
| A guide has been added for migrating systems using another init system |  | ||||||
| to openrc-init. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.41. |  | ||||||
|  |  | ||||||
| This version adds the ability to format the output of rc-status when |  | ||||||
| showing the status of services in a runlevel so that it may be parsed. |  | ||||||
| Currently, the -f switch only accepts ini as an argument which |  | ||||||
| causes the output to be in the .ini format. |  | ||||||
|  |  | ||||||
| This version adds an experimental build time switch to allow setting the |  | ||||||
| default shell to use for service scripts. |  | ||||||
| By default, this is set to /bin/sh if it is changed, the new shell must |  | ||||||
| be able to understand posix-compatible syntax. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.40 |  | ||||||
|  |  | ||||||
| In this version, the keymaps and termencoding services on Linux needed |  | ||||||
| to be modified so they do not write to the root file system. This was |  | ||||||
| done so they can run earlier in the boot sequence. AS a result, you will |  | ||||||
| need to add save-termencoding and save-keymaps to your boot runlevel. |  | ||||||
| This can be done as follows: |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| # rc-update add save-keymaps boot |  | ||||||
| # rc-update add save-termencoding boot |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## OpenRC 0.39 |  | ||||||
|  |  | ||||||
| This version removes the support for addons. |  | ||||||
| The only place I know that this was used was Gentoo Baselayout 1.x, so |  | ||||||
| it shouldn't affect anyone since baselayout-1 has been dead for a few |  | ||||||
| years. |  | ||||||
|  |  | ||||||
| Since all supported Linux kernel versions now make efivarfs immutable |  | ||||||
| and all of the tools that access efivarfs are aware of this, we no |  | ||||||
| longer mount efivarfs read-only. See the following github issue for more |  | ||||||
| information: |  | ||||||
|  |  | ||||||
| https://github.com/openrc/openrc/issues/238 |  | ||||||
|  |  | ||||||
| This version adds timed shutdown and cancelation of shutdown to |  | ||||||
| openrc-shutdown. Shutdowns can now be delayed for a certain amount of |  | ||||||
| time or scheduled for an exact time. |  | ||||||
|  |  | ||||||
| supervise-daemon supports health checks, which are a periodic way to make sure a |  | ||||||
| service is healthy. For more information on setting this up, please see |  | ||||||
| supervise-daemon-guide.md. |  | ||||||
|  |  | ||||||
| The --first-time switch has been added to all modprobe commands in the |  | ||||||
| modules service. This means that, on Linux, you will see failures if a |  | ||||||
| module was loaded by an initramfs or device manager before this service |  | ||||||
| runs. These messages are harmless, but to clean them up, you should adjust your |  | ||||||
| modules autoload configuration. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.37 |  | ||||||
|  |  | ||||||
| start-stop-daemon now supports logging stdout and stderr of daemons to |  | ||||||
| processes instead of files. These processes are defined by the |  | ||||||
| output_logger and error_logger variables in standard service scripts, or |  | ||||||
| by the  -3/--output-logger or -4/--error-logger switches if you use |  | ||||||
| start-stop-daemon directly. For more information on this, see the |  | ||||||
| start-stop-daemon man page. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.36 |  | ||||||
|  |  | ||||||
| In this release, the modules-load service has been combined into the |  | ||||||
| modules service since there is no reason I know of to keep them |  | ||||||
| separate. However, modules also provides modules-load in case you were |  | ||||||
| using modules-load in  your dependencies. |  | ||||||
|  |  | ||||||
| The consolefont, keymaps, numlock and procfs service scripts no longer |  | ||||||
| have a dependency on localmount. |  | ||||||
| If you are a linux user and are still separating / from /usr, |  | ||||||
| you will need to add the following line to the appropriate conf.d files: |  | ||||||
|  |  | ||||||
| rc_need="localmount" |  | ||||||
|  |  | ||||||
| ## OpenRC 0.35 |  | ||||||
|  |  | ||||||
| In this version, the cgroups mounting logic has been moved from the |  | ||||||
| sysfs service to the cgroups service. This was done so cgroups can be |  | ||||||
| mounted inside an lxc/lxd container without using the other parts of the |  | ||||||
| sysfs service. |  | ||||||
|  |  | ||||||
| ?As a result of this change, if you are upgrading, you need to add |  | ||||||
| cgroups to your sysinit runlevel by running the following command as |  | ||||||
| root: |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| # rc-update add cgroups sysinit |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| For more information, see the following issue: |  | ||||||
|  |  | ||||||
| https://github.com/openrc/openrc/issues/187 |  | ||||||
|  |  | ||||||
| Consider this your second notification with regard to /etc/mtab being a |  | ||||||
| file instead of a symbolic link. |  | ||||||
|  |  | ||||||
| In this version, the mtab service will complain loudly if you have |  | ||||||
| mtab_is_file set to yes and recommend that you change this to no and |  | ||||||
| restart the mtab service to migrate /etc/mtab to a symbolic link. |  | ||||||
|  |  | ||||||
| If there is a valid technical reason to keep /etc/mtab as a flat file |  | ||||||
| instead of a symbolic link to /proc/self/mounts, we are interested and |  | ||||||
| we will keep the support in that case. Please open an issue and let us |  | ||||||
| know however. Otherwise, consider this your final notice that the mtab |  | ||||||
| service will be removed in the future. |  | ||||||
|  |  | ||||||
| ## OpenRC 0.33 |  | ||||||
|  |  | ||||||
| This version removes the "service" binary which was just a copy of |  | ||||||
| "rc-service" provided for compatibility. |  | ||||||
|  |  | ||||||
| If you still need the "service" binary, as opposed to "rc-service", it is |  | ||||||
| recommended that you use something like Debian's init-system-helpers. |  | ||||||
| Otherwise, just use "rc-service" in place of "service". |  | ||||||
|  |  | ||||||
| ## OpenRC 0.31 |  | ||||||
|  |  | ||||||
| This version adds support for Control Groups version 2, which is |  | ||||||
| considered stable as of Linux-4.13. Please see /etc/rc.conf for |  | ||||||
| documentation on how to configure control groups. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.28 |  | ||||||
|  |  | ||||||
| This version mounts efivars read only due to concerns about changes in |  | ||||||
| this file system making systems unbootable.  If you need to change something |  | ||||||
| in this path, you will need to re-mount it read-write, make the change |  | ||||||
| and re-mount it read-only. |  | ||||||
|  |  | ||||||
| Also, you can override this behavior by adding a line for efivars to |  | ||||||
| fstab if you want efivars mounted read-write. |  | ||||||
|  |  | ||||||
| For more information on this issue, see the following url: |  | ||||||
|  |  | ||||||
| https://github.com/openrc/openrc/issues/134 |  | ||||||
|  |  | ||||||
| ## OpenRC-0.25 |  | ||||||
|  |  | ||||||
| This version contains an OpenRC-specific implementation of init for |  | ||||||
| Linux which can be used in place of sysvinit or any other init process. |  | ||||||
| For information on its usage, see the man pages for openrc-init (8) and |  | ||||||
| openrc-shutdown (8). |  | ||||||
|  |  | ||||||
| ## OpenRC-0.24.1 |  | ||||||
|  |  | ||||||
| This version starts cleaning up the dependencies so that rc_parallel |  | ||||||
| will work correctly. |  | ||||||
|  |  | ||||||
| The first step in this process is to remove the 'before *' from the |  | ||||||
| depend functions in the clock services. This means some  services not |  | ||||||
| controlled by OpenRC may now start before instead of after the clock |  | ||||||
| service. If it is important for these services to start after the clock |  | ||||||
| service, they need to have 'after clock' added to their depend |  | ||||||
| functions. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.24 |  | ||||||
|  |  | ||||||
| Since the deptree2dot tool and the perl requirement are completely |  | ||||||
| optional, the deptree2dot tool has been moved to the support directory. |  | ||||||
| As a result, the MKTOOLS=yes/no switch has been removed from the makefiles. |  | ||||||
|  |  | ||||||
| This version adds the agetty service which can be used to spawn |  | ||||||
| agetty on a specific terminal. This is currently documented in the |  | ||||||
| agetty-guide.md file at the top level of this distribution. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.23 |  | ||||||
|  |  | ||||||
| The tmpfiles.d processing code, which was part of previous versions of |  | ||||||
| OpenRC, has been separated into its own package [1]. If you need to |  | ||||||
| process systemd style tmpfiles.d files, please install this package. |  | ||||||
|  |  | ||||||
| [1] https://github.com/openrc/opentmpfiles |  | ||||||
|  |  | ||||||
| ## OpenRC-0.22 |  | ||||||
|  |  | ||||||
| In previous versions of OpenRC, configuration information was processed |  | ||||||
| so that service-specific configuration stored in /etc/conf.d/* was |  | ||||||
| overridden by global configuration stored in /etc/rc.conf. This release |  | ||||||
| reverses that. Global configuration is now overridden by |  | ||||||
| service-specific configuration. |  | ||||||
|  |  | ||||||
| The swapfiles service, which was basically a copy of the swap service, |  | ||||||
| has been removed. If you are only using swap partitions, this change |  | ||||||
| will not affect you. If you are using swap files, please adjust the |  | ||||||
| dependencies of the swap service as shown in /etc/conf.d/swap. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.21 |  | ||||||
|  |  | ||||||
| This version adds a daemon supervisor which can start daemons and |  | ||||||
| restart them if they crash. See supervise-daemon-guide.md in the |  | ||||||
| distribution for details on its use. |  | ||||||
|  |  | ||||||
| It is now possible to mark certain mount points as critical. If these |  | ||||||
| mount points are unable to be mounted, localmount or netmount will fail. |  | ||||||
| This is handled in /etc/conf.d/localmount and /etc/conf.d/netmount. See |  | ||||||
| these files for the setup. |  | ||||||
|  |  | ||||||
| The deprecation messages in 0.13.x for runscript and rc are now |  | ||||||
| made visible in preparation for the removal of these binaries in 1.0. |  | ||||||
|  |  | ||||||
| The steps you should take to get rid of these warnings is to run openrc |  | ||||||
| in initialization steps instead of rc and change the shebang lines in |  | ||||||
| service scripts to refer to "openrc-run" instead of "runscript". |  | ||||||
|  |  | ||||||
| In 0.21.4, a modules-load service was added. This works like the |  | ||||||
| equivalent service in systemd. It looks for files named *.conf first in |  | ||||||
| /usr/lib/modules-load.d, then /run/modules-load.d, then |  | ||||||
| /etc/modules-load.d. These files contain a list of modules, one per |  | ||||||
| line, which should be loaded into the kernel. If a file name appears in |  | ||||||
| /run/modules-load.d, it overrides a file of the same name in |  | ||||||
| /usr/lib/modules-load.d. A file appearing in /etc/modules-load.d |  | ||||||
| overrides a file of the same name in both previous directories. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.19 |  | ||||||
|  |  | ||||||
| This version adds a net-online service. By default, this |  | ||||||
| service will check all known network interfaces for a configured |  | ||||||
| interface or a carrier. It will register as started only when all |  | ||||||
| interfaces are configured and there is at least a carrier on one |  | ||||||
| interface. The behaviour of this service can be modified in |  | ||||||
| /etc/conf.d/net-online. |  | ||||||
|  |  | ||||||
| Currently, this only works on Linux, but if anyone wants to port to |  | ||||||
| *bsd, that would be welcomed. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.18.3 |  | ||||||
|  |  | ||||||
| Modern Linux systems expect /etc/mtab to be a symbolic link to |  | ||||||
| /proc/self/mounts. Reasons for this change include support for mount |  | ||||||
| namespaces, which will not work if /etc/mtab is a file. |  | ||||||
| By default, the mtab service enforces this on each reboot. |  | ||||||
|  |  | ||||||
| If you find that this breaks your system in some way, please do the |  | ||||||
| following: |  | ||||||
|  |  | ||||||
| - Set mtab_is_file=yes in /etc/conf.d/mtab. |  | ||||||
|  |  | ||||||
| - Restart mtab. This will recreate the /etc/mtab file. |  | ||||||
|  |  | ||||||
| - Check for an issue on https://github.com/openrc/openrc/issues |  | ||||||
|   explaining why you need /etc/mtab to be a file. If there isn't one, |  | ||||||
|   please open one and explain in detail why you need this to be a file. |  | ||||||
|   If there is one, please add your comments to it. Please give concrete |  | ||||||
|   examples of why  it is important that /etc/mtab be a file instead of a |  | ||||||
|   symbolic link. Those comments will be taken into consideration for how |  | ||||||
|   long to keep supporting mtab as a file or when the support can be |  | ||||||
|   removed. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.18 |  | ||||||
|  |  | ||||||
| The behaviour of localmount and netmount in this version is changing. In |  | ||||||
| the past, these services always started successfully. In this version, |  | ||||||
| they will be able to fail if file systems they mount fail to mount. If |  | ||||||
| you have file systems listed in fstab which should not be mounted at |  | ||||||
| boot time, make sure to add noauto to the mount options. If you have |  | ||||||
| file systems that you want to attempt to mount at boot time but failure |  | ||||||
| should be allowed, add nofail to the mount options for these file |  | ||||||
| systems in fstab. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.14 |  | ||||||
|  |  | ||||||
| The binfmt service, which registers misc binary formats with the Linux |  | ||||||
| kernel, has been separated from the procfs service. This service will be |  | ||||||
| automatically added to the boot runlevel for new Linux installs. When |  | ||||||
| you upgrade, you will need to use rc-update to add it to your boot |  | ||||||
| runlevel. |  | ||||||
|  |  | ||||||
| The procfs service no longer automounts the deprecated usbfs and |  | ||||||
| usbdevfs file systems. Nothing should be using usbdevfs any longer, and |  | ||||||
| if you still need usbfs it can be added to fstab. |  | ||||||
|  |  | ||||||
| Related to the above change, the procfs service no longer attempts to |  | ||||||
| modprobe the usbcore module. If your device manager does not load it, |  | ||||||
| you will need to configure the modules service to do so. |  | ||||||
|  |  | ||||||
| The override order of binfmt.d and tmpfiles.d directories has been |  | ||||||
| changed to match systemd. Files in /run/binfmt.d and /run/tmpfiles.d |  | ||||||
| override their /usr/lib counterparts, and files in the /etc counterparts |  | ||||||
| override both /usr/lib and /run. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.13.2 |  | ||||||
|  |  | ||||||
| A chroot variable has been added to the service script variables. |  | ||||||
| This fixes the support for running a service in a chroot. |  | ||||||
| This is documented in man 8 openrc-run. |  | ||||||
|  |  | ||||||
| The netmount service now mounts nfs file systems. |  | ||||||
| This change was made to correct a fix for an earlier bug. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.13 |  | ||||||
|  |  | ||||||
| /sbin/rc was renamed to /sbin/openrc and /sbin/runscript was renamed to |  | ||||||
| /sbin/openrc-run due to naming conflicts with other software. |  | ||||||
|  |  | ||||||
| Backward compatible symbolic links are currently in place so your |  | ||||||
| system will keep working if you are using the old names; however, it is |  | ||||||
| strongly advised that you migrate to the new names because the symbolic |  | ||||||
| links will be removed in the future. |  | ||||||
| Warnings have been added to assist with this migration; however, due to the |  | ||||||
| level of noise they produce, they only appear in verbose mode in this release. |  | ||||||
|  |  | ||||||
| The devfs script now handles the initial mounting and setup of the |  | ||||||
| /dev directory. If /dev has already been mounted by the kernel or an |  | ||||||
| initramfs, devfs will remount /dev with the correct mount options |  | ||||||
| instead of mounting a second /dev over the existing mount point. |  | ||||||
|  |  | ||||||
| It attempts to mount /dev from fstab first if an entry exists there. If |  | ||||||
| it doesn't it attempts to mount devtmpfs if it is configured in the |  | ||||||
| kernel. If not, it attempts to mount tmpfs. |  | ||||||
| If none of these is available, an error message is displayed and static |  | ||||||
| /dev is assumed. |  | ||||||
|  |  | ||||||
| ## OpenRC-0.12 |  | ||||||
|  |  | ||||||
| The net.* scripts, originally from Gentoo Linux, have |  | ||||||
| been removed. If you need these scripts, look for a package called |  | ||||||
| netifrc, which is maintained by them. |  | ||||||
							
								
								
									
										99
									
								
								README
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								README
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | OpenRC README | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Installation | ||||||
|  | ------------ | ||||||
|  | make install | ||||||
|  | Yup, that simple. Works with GNU make. | ||||||
|  |  | ||||||
|  | You may wish to tweak the installation with the below arguments | ||||||
|  | PROGLDFLAGS=-static | ||||||
|  | LIBNAME=lib64 | ||||||
|  | DESTDIR=/tmp/openrc-image | ||||||
|  | MKPAM=pam | ||||||
|  | MKPKGCONFIG=no | ||||||
|  | MKRCSYS=prefix | ||||||
|  | MKSELINUX=yes | ||||||
|  | MKSTATICLIBS=no | ||||||
|  | MKTERMCAP=ncurses | ||||||
|  | MKTERMCAP=termcap | ||||||
|  | PKG_PREFIX=/usr/pkg | ||||||
|  | LOCAL_PREFIX=/usr/local | ||||||
|  | PREFIX=/usr/local | ||||||
|  |  | ||||||
|  | We don't support building a static OpenRC with PAM. | ||||||
|  | You may need to use PROGLDFLAGS=-Wl,-Bstatic on glibc instead of just -static. | ||||||
|  | If you debug memory under valgrind, add -DDEBUG_MEMORY to your CPPFLAGS | ||||||
|  | so that all malloc memory should be freed at exit. | ||||||
|  |  | ||||||
|  | You can also brand OpenRC if you so wish like so | ||||||
|  | BRANDING=\"Gentoo/$(uname -s)\" | ||||||
|  |  | ||||||
|  | PKG_PREFIX should be set to where packages install to by default. | ||||||
|  | LOCAL_PREFIX should be set when to where user maintained packages are. | ||||||
|  | Only set LOCAL_PREFIX if different from PKG_PREFIX. | ||||||
|  | PREFIX should be set when OpenRC is not installed to /. | ||||||
|  |  | ||||||
|  | MKRCSYS should be set only if you need to specify a default system | ||||||
|  | subtype. The subtype should be set to match the type of environment the | ||||||
|  | file is installed into, not the virtualization the environment is | ||||||
|  | capable of handling. Here is a list of subtypes and their meanings. | ||||||
|  |  | ||||||
|  | jail	FreeBSD jail | ||||||
|  | lxc	Linux container | ||||||
|  | openvz	Linux OpenVZ | ||||||
|  | prefix	Linux and *BSD prefix system | ||||||
|  | uml	UsermodeLinux | ||||||
|  | vserver	Linux vserver | ||||||
|  | xen0 Linux and NetBSD xen0 Domain | ||||||
|  | xenU Linux and NetBSD xenU Domain | ||||||
|  |  | ||||||
|  | If any of the following files exist then we do not overwrite them | ||||||
|  | /etc/devd.conf | ||||||
|  | /etc/rc | ||||||
|  | /etc/rc.shutdown | ||||||
|  | /etc/conf.d/* | ||||||
|  |  | ||||||
|  | rc and rc.shutdown are the hooks from the BSD init into OpenRC. | ||||||
|  | devd.conf is modified from FreeBSD to call /etc/rc.devd which is a generic | ||||||
|  | hook into OpenRC. | ||||||
|  | inittab is the same, but for SysVInit as used by most Linux distributions. | ||||||
|  | This can be found in the support folder. | ||||||
|  | Obviously, if you're installing this onto a system that does not use OpenRC | ||||||
|  | by default then you may wish to backup the above listed files, remove them | ||||||
|  | and then install so that the OS hooks into OpenRC. | ||||||
|  |  | ||||||
|  | init.d.misc is not installed by default as the scripts will need | ||||||
|  | tweaking on a per distro basis. They are also non essential to the operation | ||||||
|  | of the system. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Reporting Bugs | ||||||
|  | -------------- | ||||||
|  | Since Gentoo Linux is hosting OpenRC development, Bugs should go to | ||||||
|  | the Gentoo Bugzilla: | ||||||
|  | 	http://bugs.gentoo.org/ | ||||||
|  | They should be filed under the "Gentoo Hosted Projects" product and | ||||||
|  | the "openrc" component. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | History - by Roy Marples | ||||||
|  | ------------------------ | ||||||
|  | I became a Gentoo/Linux developer in 2004 and wrote the modular network | ||||||
|  | scripts for the Gentoo baselayout package. baselayout is a collection of | ||||||
|  | bash scripts to bring up your computer and its services. | ||||||
|  | Then towards the end of 2005 I found myself as the primary maintainer | ||||||
|  | for baselayout. | ||||||
|  |  | ||||||
|  | At the start of 2007, baselayout-2 is announced to the world, re-writing the | ||||||
|  | core of baselayout in C and allowing POSIX sh init scripts instead of | ||||||
|  | forcing the use of bash. By Mid 2007 I have re-written everything, including | ||||||
|  | init scripts, and alpha and pre baselayout-2 snapshots where put into Gentoo. | ||||||
|  | Towards the end of 2007 I retired as a Gentoo developer for reasons I won't | ||||||
|  | go into here. baselayout-2 was still in the pre stage, and aside from the | ||||||
|  | fbsd users, it was masked everywhere. However, I also desired to keep the | ||||||
|  | baselayout-2 project alive, but outside of Gentoo and into other projects | ||||||
|  | such as FreeBSD. | ||||||
|  |  | ||||||
|  | As such, the Gentoo Council have allowed the creation of OpenRC under the | ||||||
|  | 2 clause BSD license, managed by me as an external project. | ||||||
							
								
								
									
										52
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										52
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,52 +0,0 @@ | |||||||
| OpenRC README |  | ||||||
| ============= |  | ||||||
|  |  | ||||||
| OpenRC is a dependency-based init system that works with the |  | ||||||
| system-provided init program, normally `/sbin/init`. |  | ||||||
|  |  | ||||||
| ## building and installing |  | ||||||
|  |  | ||||||
| OpenRC uses the  [meson](http://mesonbuild.com) build system, so use the |  | ||||||
| usual methods for this build system to build and install. |  | ||||||
|  |  | ||||||
| ## Notes |  | ||||||
|  |  | ||||||
| We don't support building a static OpenRC with PAM. |  | ||||||
|  |  | ||||||
| `PKG_PREFIX` should be set to where packages install to by default. |  | ||||||
|  |  | ||||||
| `LOCAL_PREFIX` should be set to where user maintained packages are. |  | ||||||
| Only set `LOCAL_PREFIX` if different from `PKG_PREFIX`. |  | ||||||
|  |  | ||||||
| `ROOTPREFIX` should be set when the root path is different from '/'. |  | ||||||
|  |  | ||||||
| `rc` and `rc.shutdown` are the hooks from the BSD init into OpenRC. |  | ||||||
|  |  | ||||||
| `devd.conf` is modified from FreeBSD to call `/etc/rc.devd` which is a |  | ||||||
| generic hook into OpenRC. |  | ||||||
|  |  | ||||||
| `inittab` is the same, but for SysVInit as used by most Linux distributions. |  | ||||||
| This can be found in the support folder. |  | ||||||
|  |  | ||||||
| Obviously, if you're installing this onto a system that does not use |  | ||||||
| OpenRC by default then you may wish to backup the above listed files, |  | ||||||
| remove them and then install so that the OS hooks into OpenRC. |  | ||||||
|  |  | ||||||
| ## Discussions |  | ||||||
|  |  | ||||||
| We are testing [discussions](https://github.com/OpenRC/openrc/discussions), so |  | ||||||
| feel free to open topics there. |  | ||||||
|  |  | ||||||
| ## Reporting Bugs |  | ||||||
|  |  | ||||||
| Please report bugs on our [bug tracker](http://github.com/OpenRC/openrc/issues). |  | ||||||
|  |  | ||||||
| If you can contribute code , please feel free to do so by opening |  | ||||||
| [pull requests](https://github.com/OpenRC/openrc/pulls). |  | ||||||
|  |  | ||||||
| ## IRC Channel |  | ||||||
|  |  | ||||||
| We have an official irc channel, #openrc on the libera network. |  | ||||||
| Please connect your irc client to irc.libera.chat and join #openrc on |  | ||||||
| that network. |  | ||||||
|  |  | ||||||
| @@ -1,24 +1,23 @@ | |||||||
| OpenRC Coding Style Guide |  | ||||||
| ========================= |  | ||||||
| 
 |  | ||||||
| This is the openrc style manual.  It governs the coding style of all code | This is the openrc style manual.  It governs the coding style of all code | ||||||
| in this repository.  Follow it.  Contact openrc@gentoo.org for any questions | in this repository.  Follow it.  Contact openrc@gentoo.org for any questions | ||||||
| or fixes you might notice. | or fixes you might notice. | ||||||
| 
 | 
 | ||||||
| ## C CODE | ########## | ||||||
|  | # C CODE # | ||||||
|  | ########## | ||||||
| 
 | 
 | ||||||
| The BSD Kernel Normal Form (KNF) style is used [1]. Basically, it is like | The BSD Kernel Normal Form (KNF) style is used: | ||||||
| K&R/LKML, but wrapped lines that are indented use 4 spaces. Here are the | 	http://en.wikipedia.org/wiki/Indent_style#BSD_KNF_style | ||||||
| highlights. | Basically, it's like K&R/LKML, but wrapped lines that are indented use 4 spaces. | ||||||
| 
 | 
 | ||||||
| - no trailing whitespace | Highlights: | ||||||
| - indented code use tabs (not line wrapped) | 	- no trailing whitespace | ||||||
| - cuddle the braces (except for functions) | 	- indented code use tabs (not line wrapped) | ||||||
| - space after native statements and before paren (for/if/while/...) | 	- cuddle the braces (except for functions) | ||||||
| - no space between function and paren | 	- space after native statements and before paren (for/if/while/...) | ||||||
| - pointer asterisk cuddles the variable, not the type | 	- no space between function and paren | ||||||
|  | 	- pointer asterisk cuddles the variable, not the type | ||||||
| 
 | 
 | ||||||
| ``` |  | ||||||
| void foo(int c) | void foo(int c) | ||||||
| { | { | ||||||
| 	int ret = 0; | 	int ret = 0; | ||||||
| @@ -33,15 +32,16 @@ void foo(int c) | |||||||
| 
 | 
 | ||||||
| 	return ret; | 	return ret; | ||||||
| } | } | ||||||
| ``` |  | ||||||
| 
 | 
 | ||||||
| ## COMMIT MESSAGES | ################## | ||||||
|  | # COMMIT MESSAGES # | ||||||
|  | ################## | ||||||
| 
 | 
 | ||||||
| The following is an example of a correctly formatted git commit message | The following is an example of a correctly formatted git commit message | ||||||
| for this repository. Most of this information came from this blog post | for this repository. Most of this information came from this blog post | ||||||
| [2], so I would like to thank the author. | [1], so I would like to thank the author. | ||||||
| 
 | 
 | ||||||
| ``` | ### cut here ### | ||||||
| Capitalized, short (50 chars or less) summary | Capitalized, short (50 chars or less) summary | ||||||
| 
 | 
 | ||||||
| More detailed explanatory text, if necessary.  Wrap it to about 72 | More detailed explanatory text, if necessary.  Wrap it to about 72 | ||||||
| @@ -51,7 +51,7 @@ line separating the summary from the body is critical (unless you omit | |||||||
| the body entirely); tools like rebase can get confused if you run the | the body entirely); tools like rebase can get confused if you run the | ||||||
| two together. | two together. | ||||||
| 
 | 
 | ||||||
| Write your commit message in the imperative: "Fix bug" and not "Fixed | Write your commit message in the present tense: "Fix bug" and not "Fixed | ||||||
| bug."  This convention matches up with commit messages generated by | bug."  This convention matches up with commit messages generated by | ||||||
| commands like git merge and git revert. | commands like git merge and git revert. | ||||||
| 
 | 
 | ||||||
| @@ -67,7 +67,7 @@ Further paragraphs come after blank lines. | |||||||
| Reported-by: User Name <email> | Reported-by: User Name <email> | ||||||
| X-[Distro]-Bug: BugID | X-[Distro]-Bug: BugID | ||||||
| X-[Distro]-Bug-URL: URL for the bug (on the distribution's web site typically) | X-[Distro]-Bug-URL: URL for the bug (on the distribution's web site typically) | ||||||
| ``` | ### cut here ### | ||||||
| 
 | 
 | ||||||
| If you did not write the code and the patch does not include authorship | If you did not write the code and the patch does not include authorship | ||||||
| information in a format git can use, please use the --author option of the | information in a format git can use, please use the --author option of the | ||||||
| @@ -81,5 +81,5 @@ different from the author and committer. | |||||||
|   *BSD. Also, [Distro] should be replaced with the name of the |   *BSD. Also, [Distro] should be replaced with the name of the | ||||||
|   distribution, e.g. X-Gentoo-Bug. |   distribution, e.g. X-Gentoo-Bug. | ||||||
| 
 | 
 | ||||||
| [1]	http://en.wikipedia.org/wiki/Indent_style#BSD_KNF_style | [1] http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html | ||||||
| [2] http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html | 
 | ||||||
							
								
								
									
										14
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								TODO
									
									
									
									
									
								
							| @@ -5,17 +5,3 @@ | |||||||
| - oldnet[bridging]: Review setting of bridge configuration on dynamic interface add | - oldnet[bridging]: Review setting of bridge configuration on dynamic interface add | ||||||
|  |  | ||||||
| - Document rc-depend binary. | - Document rc-depend binary. | ||||||
|  |  | ||||||
| - _ifindex is not a reliable means of calculating metrics: |  | ||||||
| 	_ifindex is used for calculating metrics for new devices but has a major |  | ||||||
| 	problem: Since it's only the nth entry in /proc/net/dev |  | ||||||
| 	And devices may be removed from that file, and reordered, you won't always |  | ||||||
| 	get the same result. |  | ||||||
| 	If you do: |  | ||||||
| 	- add eth0 - _ifindex (eth0=0) |  | ||||||
| 	- add vlan1 - _ifindex (eth0=0,vlan1=1) |  | ||||||
| 	- add vlan2 - _ifindex (eth0=0,vlan1=1,vlan2=2) |  | ||||||
| 	- rem vlan1 - _ifindex (eth0=0,vlan2=1) |  | ||||||
| 	- add vlan3 - _ifindex (eth0=0,vlan2=1,vlan3=2) |  | ||||||
| 	Now your routing table has entries for both vlan2 and vlan3 with a metric of 2. |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,19 +0,0 @@ | |||||||
| Setting up the agetty service in OpenRC |  | ||||||
| =================================xxxxxx |  | ||||||
|  |  | ||||||
| The agetty service is an OpenRC specific way to monitor and respawn a |  | ||||||
| getty, using agetty, on Linux. To use this method, make sure you aren't |  | ||||||
| spawning a getty manager for this port some other way (such as through |  | ||||||
| sysvinit/inittab), then run the following commands as root. |  | ||||||
|  |  | ||||||
| Note that [port] refers to the port you are spawning the getty on, for |  | ||||||
| example, tty1 or ttyS0. The full path to it, for example, /dev/tty1 |  | ||||||
| should not be used. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| # cd /etc/init.d |  | ||||||
| # ln -s agetty agetty.[port] |  | ||||||
| # cd /etc/conf.d |  | ||||||
| # cp agetty agetty.[port] |  | ||||||
| #rc-update add agetty.[port] [runlevel] |  | ||||||
| ``` |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| if get_option('bash-completions') |  | ||||||
| bash_completions = [ |  | ||||||
|   'openrc', |  | ||||||
|   'openrc-service-script', |  | ||||||
|   'rc-service', |  | ||||||
|   'rc-status', |  | ||||||
|   'rc-update', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| install_data(bash_completions, |  | ||||||
|   install_dir : get_option('datadir') / 'bash-completion/completions') |  | ||||||
| endif |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # openrc completion command |  | ||||||
| # |  | ||||||
| _openrc() |  | ||||||
| { |  | ||||||
| 	local cur |  | ||||||
| 	COMPREPLY=() |  | ||||||
| 	cur="${COMP_WORDS[COMP_CWORD]}" |  | ||||||
| 	if [[ ${#COMP_WORDS[*]} -le 2 ]]; then |  | ||||||
| 		COMPREPLY=($(compgen -W "$(rc-status --list)" -- $cur)) |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } && |  | ||||||
| complete -F _openrc openrc |  | ||||||
| @@ -1,29 +0,0 @@ | |||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| _openrc_service_script() |  | ||||||
| { |  | ||||||
| 	local script="${COMP_WORDS[0]}" |  | ||||||
| 	local cur="${COMP_WORDS[$COMP_CWORD]}" |  | ||||||
|  |  | ||||||
| 	if [[ ( -f "${script}" || -h "${script}" ) && -r "${script}" ]] \ |  | ||||||
| 	&& [[ "$(head -n 1 "${script}")" =~ \#\!.*/openrc-run ]] |  | ||||||
| 	then |  | ||||||
| 		[[ $COMP_CWORD -gt 1 ]] && return 1 |  | ||||||
| 		COMPREPLY=($(opts="start stop status restart pause zap ineed needsme iuse usesme broken"; \ |  | ||||||
| 			eval "$(grep '^opts=' "${script}")"; echo "${opts}")) |  | ||||||
| 		[[ -n "$COMPREPLY" ]] || COMPREPLY=(start stop restart zap) |  | ||||||
| 		COMPREPLY=($(compgen -W "${COMPREPLY[*]}" -- "${cur}")) |  | ||||||
| 	else |  | ||||||
| 		COMPREPLY=($(compgen -o default -- "${cur}")) |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
| complete -F _openrc_service_script */etc/init.d/* |  | ||||||
| @@ -1,116 +0,0 @@ | |||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # rc-service completion command |  | ||||||
| # |  | ||||||
| _rc_service() |  | ||||||
| { |  | ||||||
| 	local cur prev numwords opts |  | ||||||
| 	local words i x filename |  | ||||||
| 	local action actionpos |  | ||||||
| 	COMPREPLY=() |  | ||||||
| 	cur="${COMP_WORDS[COMP_CWORD]}" |  | ||||||
| 	prev="${COMP_WORDS[COMP_CWORD-1]}" |  | ||||||
| 	numwords=${#COMP_WORDS[*]} |  | ||||||
|  |  | ||||||
| 	if [[ ${prev} == '>' || ${prev} == '<' ]] ; then |  | ||||||
| 		COMPREPLY=($(compgen -f -- ${cur})) |  | ||||||
| 		return 0 |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	# find action |  | ||||||
| 	for x in ${COMP_LINE} ; do |  | ||||||
| 		if [[ ${x} =~ --(list|exists|resolve) ]] || [[ ${x} =~ -(l|e|r) ]] |  | ||||||
| 		then |  | ||||||
| 			action=${x} |  | ||||||
| 			break |  | ||||||
| 		fi |  | ||||||
| 	done |  | ||||||
| 	if [[ -n ${action} ]]; then |  | ||||||
| 		for ((i = 0; i < ${numwords}; i++ )); do |  | ||||||
| 			if [[ ${COMP_WORDS[${i}]} == "${action}" ]]; then |  | ||||||
| 				actionpos=${i} |  | ||||||
| 				break |  | ||||||
| 			fi |  | ||||||
| 		done |  | ||||||
|  |  | ||||||
| 		for ((i = 1; i < ${numwords}; i++ )); do |  | ||||||
| 			if [[ ! ${COMP_WORDS[$i]} == -* ]]; then |  | ||||||
| 				break |  | ||||||
| 			fi |  | ||||||
| 		done |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	if [[ ${COMP_CWORD} -eq 3 ]]; then |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	# check if an option was typed |  | ||||||
| 	if [[ ${cur} == -* ]]; then |  | ||||||
| 		if [[ ${cur} == --* ]]; then |  | ||||||
| 			opts="--list --exists --resolve" |  | ||||||
| 			COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) ) |  | ||||||
| 			return 0 |  | ||||||
| 		elif [[ ${cur} == -* ]]; then |  | ||||||
| 			opts="-l -e -r" |  | ||||||
| 			COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) ) |  | ||||||
| 			return 0 |  | ||||||
| 		fi |  | ||||||
|  |  | ||||||
| 		# NOTE: This slows things down! |  | ||||||
| 		# (Adapted from bash_completion by Ian Macdonald <ian@caliban.org>) |  | ||||||
| 		# This removes any options from the list of completions that have |  | ||||||
| 		# already been specified on the command line. |  | ||||||
| 		COMPREPLY=($(echo "${COMP_WORDS[@]}" | \ |  | ||||||
| 		(while read -d ' ' i; do |  | ||||||
| 			[[ -z ${i} ]] && continue |  | ||||||
| 			# flatten array with spaces on either side, |  | ||||||
| 			# otherwise we cannot grep on word boundaries of |  | ||||||
| 			# first and last word |  | ||||||
| 			COMPREPLY=" ${COMPREPLY[@]} " |  | ||||||
| 			# remove word from list of completions |  | ||||||
| 			COMPREPLY=(${COMPREPLY/ ${i%% *} / }) |  | ||||||
| 		done |  | ||||||
| 		echo ${COMPREPLY[@]}))) |  | ||||||
|  |  | ||||||
| 		return 0 |  | ||||||
| 	else |  | ||||||
| 		# no option was typed |  | ||||||
| 		if [[ ${COMP_CWORD} -eq 1 ]]; then			  # if first word typed |  | ||||||
| 			words="$(rc-service --list | grep ^${cur})"		  # complete for init scripts |  | ||||||
| 			COMPREPLY=($(for i in ${words} ; do \ |  | ||||||
| 			[[ ${i} == ${cur}* ]] && echo ${i} ; \ |  | ||||||
| 			done)) |  | ||||||
| 			return 0 |  | ||||||
| 		elif [[ ${COMP_CWORD} -eq 2 ]] && [[ ${prev} != -* ]]; then # if second word typed and we didn't type in a function |  | ||||||
| 			rc-service --exists "$prev" || return |  | ||||||
| 			shopt -s extglob |  | ||||||
| 			while read -r _ line; do |  | ||||||
| 				if [[ $line == +([[:alnum:]_]):* ]]; then |  | ||||||
| 					opts+="${line%%:*} " |  | ||||||
| 				fi |  | ||||||
| 			done < <(rc-service "$prev" describe 2>&1) |  | ||||||
| 			shopt -u extglob |  | ||||||
| 			COMPREPLY=( $(compgen -W "${opts}" -- ${cur}) ) |  | ||||||
| 			return 0 |  | ||||||
| 		fi |  | ||||||
| 	fi |  | ||||||
| 	if [[ ${action} == '--exists' ]] || [[ ${action} == '-e' ]] || \ |  | ||||||
| 		[[ ${action} == '--resolve' ]]  || [[ ${action} == '-r' ]]; then |  | ||||||
| 		words="$(rc-service --list | grep ^${cur})" |  | ||||||
| 		COMPREPLY=($(for i in ${words} ; do \ |  | ||||||
| 			[[ ${i} == ${cur}* ]] && echo ${i} ; \ |  | ||||||
| 		done)) |  | ||||||
| 		return 0 |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } && |  | ||||||
| complete -F _rc_service rc-service |  | ||||||
| @@ -1,31 +0,0 @@ | |||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # rc-status completion command |  | ||||||
| # |  | ||||||
| _rcstatus() |  | ||||||
| { |  | ||||||
| 	local cur |  | ||||||
| 	cur="${COMP_WORDS[COMP_CWORD]}" |  | ||||||
| 	if [[ $COMP_CWORD -eq 1 ]]; then |  | ||||||
| 		if [[ "${cur}" == --* ]]; then |  | ||||||
| 			COMPREPLY=($(compgen -W '--all --list --unused' -- ${cur})) |  | ||||||
| 		elif [[ "${cur}" == -* ]]; then |  | ||||||
| 			COMPREPLY=($(compgen -W '-a -l -u' -- ${cur})) |  | ||||||
| 		else |  | ||||||
| 			COMPREPLY=($(compgen -W "$(rc-status --list)" -- ${cur})) |  | ||||||
| 		fi |  | ||||||
| 	else |  | ||||||
| 		unset COMPREPLY |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } && |  | ||||||
| complete -F _rcstatus rc-status |  | ||||||
| @@ -1,42 +0,0 @@ | |||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # rc-update completion command |  | ||||||
| # |  | ||||||
| _rc_update() |  | ||||||
| { |  | ||||||
| 	local cur show |  | ||||||
| 	COMPREPLY=() |  | ||||||
| 	cur="${COMP_WORDS[COMP_CWORD]}" |  | ||||||
| 	if [[ $COMP_CWORD -eq 1 ]]; then |  | ||||||
| 		if [[ "${cur}" == -* ]]; then |  | ||||||
| 			COMPREPLY=($(compgen -W '-a -d -s' -- ${cur})) |  | ||||||
| 		else |  | ||||||
| 			COMPREPLY=($(compgen -W 'add del show' ${cur})) |  | ||||||
| 		fi |  | ||||||
| 	else |  | ||||||
| 		if [[ "${COMP_WORDS[1]}" == "show" ]] || [[ "${COMP_WORDS[1]}" == "-s" ]]; then |  | ||||||
| 			show="TRUE" |  | ||||||
| 		fi |  | ||||||
| 		if ([[ $COMP_CWORD -eq 3 ]] && [[ -z "$show" ]]) || \ |  | ||||||
| 			([[ $COMP_CWORD -eq 2 ]] && [[ -n "$show" ]]); then |  | ||||||
| 		COMPREPLY=($(compgen -W "$(rc-status --list)" -- $cur)) |  | ||||||
| 		elif [[ $COMP_CWORD -eq 2 ]]; then |  | ||||||
| 			COMPREPLY=($(compgen -W "$(rc-service --list)" $cur)) |  | ||||||
| 		elif [[ ${#COMP_WORDS[*]} -gt 2 ]] ; then |  | ||||||
| 			COMPREPLY=($(compgen -W "$(rc-status --list)" -- $cur)) |  | ||||||
| 		else |  | ||||||
| 			unset COMPREPLY |  | ||||||
| 		fi |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } && |  | ||||||
| complete -F _rc_update rc-update |  | ||||||
							
								
								
									
										21
									
								
								ci/cirrus.sh
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								ci/cirrus.sh
									
									
									
									
									
								
							| @@ -1,21 +0,0 @@ | |||||||
| #!/bin/bash |  | ||||||
| # Copyright (c) 2007-2018 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| set -e |  | ||||||
| set -u |  | ||||||
| set -x |  | ||||||
|  |  | ||||||
| # These are steps to run on Cirrus CI under a jailed FreeBSD system. |  | ||||||
| # See $TOP/.cirrus.yml for more info about the Cirrus CI setup. |  | ||||||
|  |  | ||||||
| meson build |  | ||||||
| meson compile -C build |  | ||||||
| meson test --verbose -C build |  | ||||||
							
								
								
									
										40
									
								
								ci/travis.sh
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								ci/travis.sh
									
									
									
									
									
								
							| @@ -1,40 +0,0 @@ | |||||||
| #!/bin/bash |  | ||||||
| # Copyright (c) 2007-2018 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| set -e |  | ||||||
| set -u |  | ||||||
| set -x |  | ||||||
|  |  | ||||||
| # These are steps to run on TravisCI under a containerized Ubuntu system. |  | ||||||
| # See $TOP/.travis.yml for more info about the TravisCI setup. |  | ||||||
|  |  | ||||||
| # Run shellcheck, but don't fail (yet): |  | ||||||
| shellcheck --version |  | ||||||
| for shellscript in $(git ls-files); do |  | ||||||
| 	case $shellscript in |  | ||||||
| 		init.d/*.in) ;; |  | ||||||
| 		sh/*.in) ;; |  | ||||||
| 		sh/*.sh) ;; |  | ||||||
| 		support/init.d.examples/*.in) ;; |  | ||||||
| 		support/openvpn/*.sh) ;; |  | ||||||
| 		support/sysvinit/halt.sh) ;; |  | ||||||
| 		test/*.sh) ;; |  | ||||||
| 		*) continue ;; |  | ||||||
| 	esac |  | ||||||
| 	echo "Checking ${shellscript} with shellcheck:" |  | ||||||
| 	shellcheck -s sh "${shellscript}" || true |  | ||||||
| done |  | ||||||
|  |  | ||||||
| cpus=$(getconf _NPROCESSORS_CONF || echo 1) |  | ||||||
| # make on TravisCI doesn't support -O yet |  | ||||||
| make -j"${cpus}" |  | ||||||
|  |  | ||||||
| make test |  | ||||||
							
								
								
									
										2
									
								
								conf.d/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								conf.d/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | network | ||||||
|  | staticroute | ||||||
							
								
								
									
										23
									
								
								conf.d/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								conf.d/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | DIR=	${CONFDIR} | ||||||
|  | CONF=	bootmisc fsck hostname localmount network staticroute urandom \ | ||||||
|  | 	${CONF-${OS}} | ||||||
|  |  | ||||||
|  | TARGETS+=	network staticroute | ||||||
|  | CLEANFILES+=	network staticroute | ||||||
|  |  | ||||||
|  | MK=	../mk | ||||||
|  | include ${MK}/os.mk | ||||||
|  |  | ||||||
|  | CONF-FreeBSD=	ipfw moused powerd rarpd savecore syscons | ||||||
|  |  | ||||||
|  | CONF-Linux=	consolefont dmesg hwclock keymaps killprocs modules | ||||||
|  |  | ||||||
|  | CONF-NetBSD=	moused rarpd savecore | ||||||
|  |  | ||||||
|  | include ${MK}/scripts.mk | ||||||
|  |  | ||||||
|  | network: network.in network${SFX} | ||||||
|  | 	cat $^ > $@ | ||||||
|  |  | ||||||
|  | staticroute: staticroute${SFX} | ||||||
|  | 	cp $@${SFX} $@ | ||||||
| @@ -1,11 +0,0 @@ | |||||||
| # make agetty quiet |  | ||||||
| #quiet="yes" |  | ||||||
|  |  | ||||||
| # Set the baud rate of the terminal line |  | ||||||
| #baud="" |  | ||||||
|  |  | ||||||
| # set the terminal type |  | ||||||
| #term_type="linux" |  | ||||||
|  |  | ||||||
| # extra options to pass to agetty for this port |  | ||||||
| #agetty_options="" |  | ||||||
| @@ -8,8 +8,3 @@ wipe_tmp="YES" | |||||||
| # Write the initial dmesg log into /var/log/dmesg after boot | # Write the initial dmesg log into /var/log/dmesg after boot | ||||||
| # This may be useful if you need the kernel boot log afterwards | # This may be useful if you need the kernel boot log afterwards | ||||||
| log_dmesg="YES" | log_dmesg="YES" | ||||||
|  |  | ||||||
| # Save the previous dmesg log to dmesg.old |  | ||||||
| # This may be useful if you need to compare the current boot to the |  | ||||||
| # previous one. |  | ||||||
| #previous_dmesg=no |  | ||||||
|   | |||||||
| @@ -1,10 +1,9 @@ | |||||||
| # The consolefont service is not activated by default. If you need to |  | ||||||
| # use it, you should run "rc-update add consolefont boot" as root. |  | ||||||
| # |  | ||||||
| # consolefont specifies the default font that you'd like Linux to use on the | # consolefont specifies the default font that you'd like Linux to use on the | ||||||
| # console.  You can find a good selection of fonts in /usr/share/consolefonts; | # console.  You can find a good selection of fonts in /usr/share/consolefonts; | ||||||
| # you shouldn't specify the trailing ".psf.gz", just the font name below. | # you shouldn't specify the trailing ".psf.gz", just the font name below. | ||||||
| # To use the default console font, comment out the CONSOLEFONT setting below. | # To use the default console font, comment out the CONSOLEFONT setting below. | ||||||
|  | # This setting is used by the /etc/init.d/consolefont script (NOTE: if you do | ||||||
|  | # not want to use it, run "rc-update del consolefont boot" as root). | ||||||
| consolefont="default8x16" | consolefont="default8x16" | ||||||
|  |  | ||||||
| # consoletranslation is the charset map file to use.  Leave commented to use | # consoletranslation is the charset map file to use.  Leave commented to use | ||||||
|   | |||||||
| @@ -1,8 +0,0 @@ | |||||||
| # OpenRC will attempt each of the following in succession to mount /dev. |  | ||||||
| # |  | ||||||
| # 1. If there is an entry for /dev in fstab, it will be used. |  | ||||||
| # 2. If devtmpfs is defined in the kernel, it will be used. |  | ||||||
| # 3. If tmpfs is defined in the kernel, it will be used. |  | ||||||
| # |  | ||||||
| # Set this to yes if you do not want OpenRC to attempt to mount /dev. |  | ||||||
| # skip_mount_dev="NO" |  | ||||||
| @@ -1,3 +1,3 @@ | |||||||
| # Sets the level at which logging of messages is done to the | # Sets the level at which logging of messages is done to the | ||||||
| # console.  See dmesg(1) for more info. | # console.  See dmesg(8) for more info. | ||||||
| dmesg_level="1" | dmesg_level="1" | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ | |||||||
| # We can also specify the passno in /etc/fstab to check | # We can also specify the passno in /etc/fstab to check | ||||||
| # If you multiplex fsck (ie ln -s fsck /etc/init.d/fsck.late) then you can | # If you multiplex fsck (ie ln -s fsck /etc/init.d/fsck.late) then you can | ||||||
| # do an fsck outside of the normal scope, say for /home. | # do an fsck outside of the normal scope, say for /home. | ||||||
| # Here are some examples:- | # Here are some exampes:- | ||||||
| #fsck_passno="=1 =2" | #fsck_passno="=1 =2" | ||||||
| #fsck_passno=">1" | #fsck_passno=">1" | ||||||
| #fsck_passno="<2" | #fsck_passno="<2" | ||||||
| @@ -32,9 +32,3 @@ fsck_on_battery="YES" | |||||||
| # This is useful when periodic filesystem checks are causing undesirable | # This is useful when periodic filesystem checks are causing undesirable | ||||||
| # delays at startup, but such delays at shutdown are acceptable. | # delays at startup, but such delays at shutdown are acceptable. | ||||||
| fsck_shutdown="NO" | fsck_shutdown="NO" | ||||||
|  |  | ||||||
| # fsck_abort_on_errors can be set to no to cause fsck to not abort on |  | ||||||
| # errors. |  | ||||||
| # This is useful when periodic filesystem checks are causing undesirable |  | ||||||
| # aborts. |  | ||||||
| fsck_abort_on_errors="YES" |  | ||||||
|   | |||||||
| @@ -1,2 +1,2 @@ | |||||||
| # Hostname fallback if /etc/hostname does not exist | # Set to the hostname of this machine | ||||||
| hostname="localhost" | hostname="localhost" | ||||||
|   | |||||||
| @@ -4,16 +4,18 @@ | |||||||
| # you should set it to "local". | # you should set it to "local". | ||||||
| clock="UTC" | clock="UTC" | ||||||
|  |  | ||||||
| # If you want the hwclock script to set the system time (software clock) | # If you want to set the Hardware Clock to the current System Time  | ||||||
| # to match the current hardware clock during bootup, leave this | # (software clock) during shutdown, then say "YES" here. | ||||||
| # commented out. | # You normally don't need to do this if you run a ntp daemon. | ||||||
| # However, you can set this to "NO" if you are running a modern kernel | clock_systohc="NO" | ||||||
| # and using NTP to synchronize your system clock. |  | ||||||
| #clock_hctosys="YES" |  | ||||||
|  |  | ||||||
| # If you do not want to set the hardware clock to the current system | # If you want to set the system time to the current hardware clock | ||||||
| # time (software clock) during shutdown, set this to no. | # during bootup, then say "YES" here. You do not need this if you are | ||||||
| #clock_systohc="YES" | # running a modern kernel with CONFIG_RTC_HCTOSYS set to y. | ||||||
|  | # Also, be aware that if you set this to "NO", the system time will | ||||||
|  | # never be saved to the hardware clock unless you set | ||||||
|  | # clock_systohc="YES" above. | ||||||
|  | clock_hctosys="YES" | ||||||
|   |   | ||||||
| # If you wish to pass any other arguments to hwclock during bootup, | # If you wish to pass any other arguments to hwclock during bootup, | ||||||
| # you may do so here. Alpha users may wish to use --arc or --srm here. | # you may do so here. Alpha users may wish to use --arc or --srm here. | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| # ipfw provides a stateful firewall. | # ipfw provides a stateful firewall. | ||||||
| # This means we allow everything out, and if we have a connection we allow it | # This means we allow everything out, and if we have a connection we allow it | ||||||
| # back in. This is very flexible and quite secure. | # back in. This is very flexable and quite secure. | ||||||
|  |  | ||||||
| # For ease of use, we allow auth and ssh ports through as well. | # For ease of use, we allow auth and ssh ports through as well. | ||||||
| # To override the list of allowed ports | # To override the list of allowed ports | ||||||
|   | |||||||
| @@ -18,6 +18,6 @@ extended_keymaps="" | |||||||
| # For a list of valid sets, run `dumpkeys --help` | # For a list of valid sets, run `dumpkeys --help` | ||||||
| dumpkeys_charset="" | dumpkeys_charset="" | ||||||
|  |  | ||||||
| # Some fonts map AltGr-E to the currency symbol instead of the Euro. | # Some fonts map AltGr-E to the currency symbol ¤ instead of the Euro € | ||||||
| # To fix this, set to "yes" | # To fix this, set to "yes" | ||||||
| fix_euro="NO" | fix_euro="NO" | ||||||
|   | |||||||
| @@ -1,11 +1,3 @@ | |||||||
| # If you wish to pass any options to kill_all during shutdown, | # If you wish to pass any options to killall5 during shutdown, | ||||||
| # you should do so here. | # you should do so here. | ||||||
| # |  | ||||||
| # The setting is called killall5_opts because the options here are meant |  | ||||||
| # to be identical to those you could pass to killall5. |  | ||||||
| killall5_opts="" | killall5_opts="" | ||||||
|  |  | ||||||
| # If you need to delay after each kill attempt during shutdown, set the amount |  | ||||||
| # of time you need to delay here. This gets passed directly to sleep in |  | ||||||
| # the shell. |  | ||||||
| # kill_delay=0 |  | ||||||
|   | |||||||
| @@ -1,10 +1,3 @@ | |||||||
| # Stop the unmounting of certain points. | # Stop the unmounting of certain points. | ||||||
| # This could be useful for some NFS related work. | # This could be useful for some NFS related work. | ||||||
| #no_umounts="/dir1:/var/dir2" | #no_umounts="/dir1:/var/dir2" | ||||||
| # |  | ||||||
| # Mark certain mount points as critical. |  | ||||||
| # This contains a space separated list of mount points which should be |  | ||||||
| # considered critical. If one of these mount points cannot be mounted, |  | ||||||
| # localmount will fail. |  | ||||||
| # By default, this is empty. |  | ||||||
| #critical_mounts="/home /var" |  | ||||||
|   | |||||||
| @@ -1,62 +0,0 @@ | |||||||
| conf_d_dir = get_option('sysconfdir') / 'conf.d' |  | ||||||
|  |  | ||||||
| conf_common = [ |  | ||||||
|   'bootmisc', |  | ||||||
|   'fsck', |  | ||||||
|   'hostname', |  | ||||||
|   'localmount', |  | ||||||
|   'netmount', |  | ||||||
|   'swap', |  | ||||||
|   'swclock', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| conf_net = [ |  | ||||||
|   'network', |  | ||||||
|   'staticroute', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| conf_FreeBSD = [ |  | ||||||
|   'ipfw', |  | ||||||
|   'modules', |  | ||||||
|   'moused', |  | ||||||
|   'powerd', |  | ||||||
|   'rarpd', |  | ||||||
|   'savecore', |  | ||||||
|   'syscons', |  | ||||||
|   'urandom', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| conf_Linux = [ |  | ||||||
|   'agetty', |  | ||||||
|   'consolefont', |  | ||||||
|   'devfs', |  | ||||||
|   'dmesg', |  | ||||||
|   'hwclock', |  | ||||||
|   'keymaps', |  | ||||||
|   'killprocs', |  | ||||||
|   'modules', |  | ||||||
|   'mtab', |  | ||||||
|   'net-online', |  | ||||||
|   'seedrng', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| conf_NetBSD =  [ |  | ||||||
|   'moused', |  | ||||||
|   'rarpd', |  | ||||||
|   'savecore', |  | ||||||
|   'urandom', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| conf_data = conf_common |  | ||||||
| if get_option('newnet') |  | ||||||
|   conf_data = conf_data + conf_net |  | ||||||
| endif |  | ||||||
| if os == 'FreeBSD' |  | ||||||
|   conf_data = conf_data + conf_FreeBSD |  | ||||||
| elif os == 'Linux' |  | ||||||
|   conf_data = conf_data + conf_Linux |  | ||||||
| elif os == 'NetBSD' |  | ||||||
|   conf_data = conf_data + conf_NetBSD |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| install_data(conf_data, install_dir : conf_d_dir) |  | ||||||
| @@ -1,17 +1,18 @@ | |||||||
| # Linux users can define a list of modules for a specific kernel version, | # You can define a list modules for a specific kernel version, | ||||||
| # a released kernel version, a main kernel version or all kernel versions. | # a released kernel version, a main kernel version or just a list. | ||||||
| # The most specific versioned variable will take precedence. | # The most specific versioned variable will take precedence. | ||||||
| # FreeBSD users can only use the modules="foo bar" setting. |  | ||||||
| #modules_2_6_23_gentoo_r5="ieee1394 ohci1394" | #modules_2_6_23_gentoo_r5="ieee1394 ohci1394" | ||||||
| #modules_2_6_23="tun ieee1394" | #modules_2_6_23="tun ieee1394" | ||||||
| #modules_2_6="tun" | #modules_2_6="tun" | ||||||
| #modules_2="ipv6" | #modules_2="ipv6" | ||||||
| #modules="ohci1394" | #modules="ohci1394" | ||||||
|  |  | ||||||
| # Linux users can give the modules some arguments if needed, per version | # You can give modules a different name when they load - the new name | ||||||
| # if necessary. | # will also be used to pick arguments below. | ||||||
|  | #modules="dummy:dummy1" | ||||||
|  |  | ||||||
|  | # Give the modules some arguments if needed, per version if necessary. | ||||||
| # Again, the most specific versioned variable will take precedence. | # Again, the most specific versioned variable will take precedence. | ||||||
| # This is not supported on FreeBSD. |  | ||||||
| #module_ieee1394_args="debug" | #module_ieee1394_args="debug" | ||||||
| #module_ieee1394_args_2_6_23_gentoo_r5="debug2" | #module_ieee1394_args_2_6_23_gentoo_r5="debug2" | ||||||
| #module_ieee1394_args_2_6_23="debug3" | #module_ieee1394_args_2_6_23="debug3" | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								conf.d/mtab
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								conf.d/mtab
									
									
									
									
									
								
							| @@ -1,13 +0,0 @@ | |||||||
| # As far as we are aware, there are no modern linux tools or use cases |  | ||||||
| # which require /etc/mtab to be a separate file from /proc/self/mounts, |  | ||||||
| # so this setting should be commented out. |  | ||||||
| # If it is set to yes, please comment it out and run this command: |  | ||||||
| # # rc-service mtab restart |  | ||||||
| # In the future, the mtab service will be removed since we are not aware |  | ||||||
| # of any need to manipulate /etc/mtab as a separate file from |  | ||||||
| # /proc/self/mounts. |  | ||||||
| # If you have a technical reason we should keep this support, please |  | ||||||
| # open an issue at https://github.com/openrc/openrc/issues and let us |  | ||||||
| # know about your situation. |  | ||||||
| # This setting controls whether /etc/mtab is a file or symbolic link. |  | ||||||
| # mtab_is_file=no |  | ||||||
							
								
								
									
										4
									
								
								conf.d/net
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								conf.d/net
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | # This blank configuration will automatically use DHCP for any net.* | ||||||
|  | # scripts in /etc/init.d.  To create a more complete configuration, | ||||||
|  | # please review /usr/share/doc/openrc*/net.example* and save your configuration | ||||||
|  | # in /etc/conf.d/net (this file :]!). | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| # The interfaces setting controls which interfaces the net-online |  | ||||||
| # service considers in deciding whether the network is active. The |  | ||||||
| # default is all interfaces that support ethernet. |  | ||||||
| #interfaces="" |  | ||||||
|  |  | ||||||
| # This setting controls whether a ping test is included in the test for |  | ||||||
| # network connectivity after all interfaces are active. |  | ||||||
| #include_ping_test=no |  | ||||||
|  |  | ||||||
| # This setting is the host to attempt to ping if the above is yes. |  | ||||||
| # The default is google.com. |  | ||||||
| #ping_test_host=some.host.name |  | ||||||
|  |  | ||||||
| # The timeout setting controls how long the net-online service waits |  | ||||||
| # for the network to be configured. |  | ||||||
| # The default is 120 seconds. |  | ||||||
| # if this is set to 0, the wait is infinite. |  | ||||||
| #timeout=120 |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| # You will need to set the dependencies in the netmount script to match |  | ||||||
| # the network configuration tools you are using. This should be done in |  | ||||||
| # this file by following the examples below, and not by changing the |  | ||||||
| # service script itself. |  | ||||||
| # |  | ||||||
| # Each of these examples is meant to be used separately. So, for |  | ||||||
| # example, do not set rc_need to something like "net.eth0 dhcpcd". |  | ||||||
| # |  | ||||||
| # If you are using newnet and configuring your interfaces with static |  | ||||||
| # addresses with the network script, you  should use this setting. |  | ||||||
| # |  | ||||||
| #rc_need="network" |  | ||||||
| # |  | ||||||
| # If you are using oldnet, you must list the specific net.* services you |  | ||||||
| # need. |  | ||||||
| # |  | ||||||
| # This example assumes all of your netmounts can be reached on |  | ||||||
| # eth0. |  | ||||||
| # |  | ||||||
| #rc_need="net.eth0" |  | ||||||
| # |  | ||||||
| # This example assumes some of your netmounts are on eth1 and some |  | ||||||
| # are on eth2. |  | ||||||
| # |  | ||||||
| #rc_need="net.eth1 net.eth2" |  | ||||||
| # |  | ||||||
| # If you are using a dynamic network management tool like |  | ||||||
| # NetworkManager, dhcpcd in standalone mode, wicd, badvpn-ncd, etc, to |  | ||||||
| # manage the network interfaces with the routes to your netmounts, you |  | ||||||
| # should list that tool. |  | ||||||
| # |  | ||||||
| #rc_need="NetworkManager" |  | ||||||
| #rc_need="dhcpcd" |  | ||||||
| #rc_need="wicd" |  | ||||||
| # |  | ||||||
| # The default setting is designed to be backward compatible with our |  | ||||||
| # current setup, but you are highly discouraged from using this. In |  | ||||||
| # other words, please change it to be more suited to your system. |  | ||||||
| # |  | ||||||
| rc_need="net" |  | ||||||
| # |  | ||||||
| # Mark certain mount points as critical. |  | ||||||
| # This contains aspace separated list of mount points which should be |  | ||||||
| # considered critical. If one of these mount points cannot be mounted, |  | ||||||
| # netmount will fail. |  | ||||||
| # By default, this is empty. |  | ||||||
| #critical_mounts="/home /var" |  | ||||||
| @@ -1,80 +0,0 @@ | |||||||
| # Assign static IP addresses and run custom scripts per interface. |  | ||||||
| # Separate commands with ; |  | ||||||
| # Prefix with ! to run a shell script. |  | ||||||
| # Use \$int to represent the interface |  | ||||||
| #ifconfig_eth0="192.168.0.10 netmask 255.255.255.0" |  | ||||||
|  |  | ||||||
| # You also have ifup_eth0 and ifdown_eth0 to run other commands when |  | ||||||
| # eth0 is started and stopped. |  | ||||||
| # You should note that we don't stop the network at system shutdown by default. |  | ||||||
| # If you really need this, then set keep_network=NO |  | ||||||
|  |  | ||||||
| # Lastly, the interfaces variable pulls in virtual interfaces that cannot |  | ||||||
| # be automatically detected. |  | ||||||
| #interfaces="br0 bond0 vlan0" |  | ||||||
|  |  | ||||||
| # You can also use files instead of variables here if you like: |  | ||||||
| # /etc/ifconfig.eth0 is equivalent to ifconfig_eth0 |  | ||||||
| # /etc/ip.eth0 is equivalent to ifconfig_eth0 |  | ||||||
| # /etc/ifup.eth0 is equivalent to ifup_eth0 |  | ||||||
| # /etc/ifdown.eth0 is equivalent to ifdown_eth0 |  | ||||||
| # Any files found will automatically be put into the interfaces variable. |  | ||||||
| # You don't need to escape variables in files, so use $int instead of \$int. |  | ||||||
|  |  | ||||||
| # If you require DHCP, you should install dhcpcd and add it to the boot or |  | ||||||
| # default runlevel. |  | ||||||
|  |  | ||||||
| # NIS users can set the domain name here |  | ||||||
| #domainname="foobar" |  | ||||||
|  |  | ||||||
| # You can add a default route. |  | ||||||
| # The way this is done is slightly different depending on the operating system. |  | ||||||
| # |  | ||||||
| # *BSD: |  | ||||||
| #defaultroute="192.168.0.1" |  | ||||||
| #defaultroute6="2001:a:b:c" |  | ||||||
| #Hurd/Linux (ifconfig): |  | ||||||
| #defaultroute="gw 192.168.0.1" |  | ||||||
| #defaultroute6="gw 2001:a:b:c" |  | ||||||
|  |  | ||||||
| # The remainder of this file applies to Linux only and shows how |  | ||||||
| # iproute2 is supported along with other examples. |  | ||||||
|  |  | ||||||
| # ifconfig under Linux is not that powerful and doesn't easily handle |  | ||||||
| # multiple addresses |  | ||||||
| # On the other hand, iproute2 is quite powerful and is also supported |  | ||||||
| #ip_eth0="192.168.0.10/24; 192.168.10.10/24" |  | ||||||
|  |  | ||||||
| # You can also use iproute2 to add the default route. |  | ||||||
| #defaultiproute="via 192.168.0.1" |  | ||||||
| #defaultiproute6="via 2001:a:b:c" |  | ||||||
|  |  | ||||||
| # ip doesn't handle MTU like ifconfig, but we can do it like so |  | ||||||
| #ifup_eth0="ip link set \$int mtu 1500" |  | ||||||
|  |  | ||||||
| # Create a bonded interface |  | ||||||
| #interfaces="bond0" |  | ||||||
| #ifup_bond0="modprobe bonding; ifconfig \$int up; ifenslave \$int bge0" |  | ||||||
| #ifconfig_bond0="192.168.0.10 netmask 255.255.255.0" |  | ||||||
| #ifdown_bond0="rmmod bonding" |  | ||||||
|  |  | ||||||
| # Create tap interface and a bridge interface. |  | ||||||
| # We add the tap to the bridge. |  | ||||||
| # An external program, like dhcpcd, will configure the IP on the bridge |  | ||||||
| #interfaces="tun0 br0" |  | ||||||
| #ifup_tun0="tunctl -t \$int" |  | ||||||
| #ifdown_tun0="tunctl -d \$int" |  | ||||||
| #ifup_br0="brctl addbr \$int; brctl add \$int eth1; brtctl add \$int eth2" |  | ||||||
| #ifdown_br0="ifconfig \$int down; btctl delbr \$int" |  | ||||||
|  |  | ||||||
| # Create VLAN |  | ||||||
| #interfaces="eth0_2 eth0_3 eth0_4" |  | ||||||
| #ifup_eth0="vconfig add \$int 2; vconfig add \$int 3; vconfig add \$int 4" |  | ||||||
| #ifconfig_eth0_2="192.168.2.10 netmask 255.255.255.0" |  | ||||||
| #ifconfig_eth0_3="192.168.3.10 netmask 255.255.255.0" |  | ||||||
| #ifconfig_eth0_4="192.168.4.10 netmask 255.255.255.0" |  | ||||||
| #ifdown_eth0="vconfig rem \$int.2; vconfig rem \$int.3; vconfig rem \$int.4" |  | ||||||
|  |  | ||||||
| # Normally you would use wpa_supplicant to configure wireless, but you can |  | ||||||
| # use iwconfig also |  | ||||||
| #ifup_wlan0="iwconfig \$int key s:secretkey enc open essid foobar" |  | ||||||
							
								
								
									
										4
									
								
								conf.d/network.BSD.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								conf.d/network.BSD.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  |  | ||||||
|  | # You can assign a default route | ||||||
|  | #defaultroute="192.168.0.1" | ||||||
|  | #defaultroute6="2001:a:b:c" | ||||||
							
								
								
									
										43
									
								
								conf.d/network.Linux.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								conf.d/network.Linux.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  |  | ||||||
|  | # You can assign a default route | ||||||
|  | #defaultroute="gw 192.168.0.1" | ||||||
|  | #defaultroute6="gw 2001:a:b:c" | ||||||
|  |  | ||||||
|  | # ifconfig under Linux is not that powerful and doesn't easily handle | ||||||
|  | # multiple addresses | ||||||
|  | # On the other hand, ip (iproute2) is quite powerful and is also supported | ||||||
|  | #ip_eth0="192.168.0.10/24; 192.168.10.10/24" | ||||||
|  |  | ||||||
|  | # You can also use ip to add the default route. | ||||||
|  | #defaultiproute="via 192.168.0.1" | ||||||
|  | #defaultiproute6="via 2001:a:b:c" | ||||||
|  |  | ||||||
|  | # ip doesn't handle MTU like ifconfig, but we can do it like so | ||||||
|  | #ifup_eth0="ip link set \$int mtu 1500" | ||||||
|  |  | ||||||
|  | # Create a bonded interface | ||||||
|  | #interfaces="bond0" | ||||||
|  | #ifup_bond0="modprobe bonding; ifconfig \$int up; ifenslave \$int bge0" | ||||||
|  | #ifconfig_bond0="192.168.0.10 netmask 255.255.255.0" | ||||||
|  | #ifdown_bond0="rmmod bonding" | ||||||
|  |  | ||||||
|  | # Create tap interface and a bridge interface. | ||||||
|  | # We add the tap to the bridge. | ||||||
|  | # An external program, like dhcpcd, will configure the IP on the bridge | ||||||
|  | #interfaces="tun0 br0" | ||||||
|  | #ifup_tun0="tunctl -t \$int" | ||||||
|  | #ifdown_tun0="tunctl -d \$int" | ||||||
|  | #ifup_br0="brctl addbr \$int; brctl add \$int eth1; brtctl add \$int eth2" | ||||||
|  | #ifdown_br0="ifconfig \$int down; btctl delbr \$int" | ||||||
|  |  | ||||||
|  | # Create VLAN | ||||||
|  | #interfaces="eth0_2 eth0_3 eth0_4" | ||||||
|  | #ifup_eth0="vconfig add \$int 2; vconfig add \$int 3; vconfig add \$int 4" | ||||||
|  | #ifconfig_eth0_2="192.168.2.10 netmask 255.255.255.0" | ||||||
|  | #ifconfig_eth0_3="192.168.3.10 netmask 255.255.255.0" | ||||||
|  | #ifconfig_eth0_4="192.168.4.10 netmask 255.255.255.0" | ||||||
|  | #ifdown_eth0="vconfig rem \$int.2; vconfig rem \$int.3; vconfig rem \$int.4" | ||||||
|  |  | ||||||
|  | # Normally you would use wpa_supplicant to configure wireless, but you can | ||||||
|  | # use iwconfig also | ||||||
|  | #ifup_wlan0="iwconfig \$int key s:secretkey enc open essid foobar" | ||||||
							
								
								
									
										28
									
								
								conf.d/network.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								conf.d/network.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | |||||||
|  | # Assign static IP addresses and run custom scripts per interface. | ||||||
|  | # Seperate commands with ; | ||||||
|  | # Prefix with ! to run a shell script. | ||||||
|  | # Use \$int to represent the interface | ||||||
|  | #ifconfig_eth0="192.168.0.10 netmask 255.255.255.0" | ||||||
|  |  | ||||||
|  | # You also have ifup_eth0 and ifdown_eth0 to run other commands when | ||||||
|  | # eth0 is started and stopped. | ||||||
|  | # You should note that we don't stop the network at system shutdown by default. | ||||||
|  | # If you really need this, then set shutdown_network=YES | ||||||
|  |  | ||||||
|  | # Lastly, the interfaces variable pulls in virtual interfaces that cannot | ||||||
|  | # be automatically detected. | ||||||
|  | #interfaces="br0 bond0 vlan0" | ||||||
|  |  | ||||||
|  | # You can also use files instead of variables here if you like: | ||||||
|  | # /etc/ifconfig.eth0 is equivalent to ifconfig_eth0 | ||||||
|  | # /etc/ip.eth0 is equivalent to ifconfig_eth0 | ||||||
|  | # /etc/ifup.eth0 is equivalent to ifup_eth0 | ||||||
|  | # /etc/ifdown.eth0 is equivalent to ifdown_eth0 | ||||||
|  | # Any files found will automatically be put into the interfaces variable. | ||||||
|  | # You don't need to escape variables in files, so use $int instead of \$int. | ||||||
|  |  | ||||||
|  | # If you require DHCP, you should install dhcpcd and it to the boot or | ||||||
|  | # default runlevel. | ||||||
|  |  | ||||||
|  | # NIS users can set the domain name here | ||||||
|  | #domainname="foobar" | ||||||
| @@ -3,5 +3,5 @@ | |||||||
| powerd_ac_mode="maximum" | powerd_ac_mode="maximum" | ||||||
| #powerd_battery_mode="minimum" | #powerd_battery_mode="minimum" | ||||||
|  |  | ||||||
| # Additional arguments for powerd - see the man page for details | # Addiditonal arguments for powerd - see the man page for details | ||||||
| powerd_args="" | powerd_args="" | ||||||
|   | |||||||
| @@ -1,14 +0,0 @@ | |||||||
| # The convention in this file is to show the default settings commented out. |  | ||||||
| # |  | ||||||
| # Sometimes you want to have urandom start before "localmount" (say for crypt |  | ||||||
| # swap), so you will need to customize this behavior.  If you have /var on a |  | ||||||
| # separate partition, make sure paths under /var are adjusted to point to |  | ||||||
| # locations on your root device. |  | ||||||
| # |  | ||||||
| # Set skip_credit to yes or true if you do not want seed files to actually |  | ||||||
| # credit the random number generator. For example, you should set this if you |  | ||||||
| # plan to replicate the file system image without removing the contents of |  | ||||||
| # ${seed_dir}. |  | ||||||
| # |  | ||||||
| # seed_dir=/var/lib/seedrng |  | ||||||
| # skip_credit=no |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| # Static routes are defined differently depending on your operating |  | ||||||
| # system, so please be sure to use the correct syntax. |  | ||||||
| # Do not use this file to define the default route. |  | ||||||
| # In all settings, multiple routes should be separated using ; or new lines. |  | ||||||
|  |  | ||||||
| # Define static routes on Linux using route. See route(8) for syntax. |  | ||||||
| #staticroute="net 192.168.0.0 netmask 255.255.255.0 gw 10.73.1.1 |  | ||||||
| #net 192.168.1.0 netmask 255.255.255.0 gw 10.73.1.1" |  | ||||||
|  |  | ||||||
| # Define static routes on Linux using iproute2. See ip(8) for syntax. |  | ||||||
| #staticiproute="192.168.0.0/24 via 10.73.1.1; 192.168.1.0/24 via 10.73.1.1" |  | ||||||
|  |  | ||||||
| # Define static routes on GNU/Hurd. See route(8) for syntax. |  | ||||||
| # /etc/route.conf(5) takes precedence over this configuration. |  | ||||||
| # FIXME: "net ..." not supported |  | ||||||
| #staticroute="net 192.168.0.0 -netmask 255.255.255.0 --address 10.73.1.1 |  | ||||||
| #net 192.168.1.0 -netmask 255.255.255.0 --address 10.73.1.1" |  | ||||||
|  |  | ||||||
| # Define static routes on GNU/KFreeBSD. See route(8) for syntax. |  | ||||||
| #staticroute="net 192.168.0.0 10.73.1.1 netmask 255.255.255.0 |  | ||||||
| #net 192.168.1.0 10.73.1.1 netmask 255.255.255.0" |  | ||||||
|  |  | ||||||
| # Define static routes on other BSD systems. See route(8) for syntax. |  | ||||||
| # /etc/route.conf(5) takes precedence over this configuration. |  | ||||||
| #staticroute="net 192.168.0.0 -netmask 255.255.255.0 10.73.1.1 |  | ||||||
| #net 192.168.1.0 -netmask 255.255.255.0 10.73.1.1" |  | ||||||
							
								
								
									
										6
									
								
								conf.d/staticroute.BSD.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								conf.d/staticroute.BSD.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | # Separate multiple routes using ; or new lines. | ||||||
|  | # /etc/route.conf(5) takes precedence over this configuration. | ||||||
|  |  | ||||||
|  | # Example static routes. See route(8) for syntax. | ||||||
|  | #staticroute="net 192.168.0.0 -netmask 255.255.255.0 10.73.1.1 | ||||||
|  | #net 192.168.1.0 -netmask 255.255.255.0 10.73.1.1" | ||||||
							
								
								
									
										8
									
								
								conf.d/staticroute.Linux.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								conf.d/staticroute.Linux.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | # Separate multiple routes using ; or new lines. | ||||||
|  |  | ||||||
|  | # Example static routes. See route(8) for syntax. | ||||||
|  | #staticroute="net 192.168.0.0 netmask 255.255.255.0 gw 10.73.1.1 | ||||||
|  | #net 192.168.1.0 netmask 255.255.255.0 gw 10.73.1.1" | ||||||
|  |  | ||||||
|  | # Example static routes using iproute2. See ip(8) for syntax. | ||||||
|  | #staticiproute="192.168.0.0/24 via 10.73.1.1; 192.168.1.0/24 via 10.73.1.1" | ||||||
							
								
								
									
										13
									
								
								conf.d/swap
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								conf.d/swap
									
									
									
									
									
								
							| @@ -1,13 +0,0 @@ | |||||||
| # If you are only using local swap partitions, you should not change |  | ||||||
| # this file. Otherwise, you need to uncomment the below rc_before line |  | ||||||
| # followed by the appropriate rc_need line. |  | ||||||
| #rc_before="!localmount" |  | ||||||
| # |  | ||||||
| # If you are using swap files stored on local file systems, uncomment |  | ||||||
| # this line. |  | ||||||
| #rc_need="localmount" |  | ||||||
| # |  | ||||||
| # If you are using swap files stored on network file systems or swap |  | ||||||
| # partitions stored on network block devices such as iSCSI, uncomment |  | ||||||
| # this line. |  | ||||||
| #rc_need="netmount" |  | ||||||
| @@ -1,6 +0,0 @@ | |||||||
| # This is the location of the reference file swclock uses to set the |  | ||||||
| # system date and time. |  | ||||||
| # This is the default path. If you are using it, you do not need to |  | ||||||
| # uncomment it. If you are using the default and have /var on its own |  | ||||||
| # file system, you need to add the appropriate rc_after setting. |  | ||||||
| # swclock_file=/var/lib/misc/openrc-shutdowntime |  | ||||||
							
								
								
									
										1
									
								
								doc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								doc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | net.example | ||||||
							
								
								
									
										11
									
								
								doc/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								doc/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | DIR=	${DOCDIR}/openrc | ||||||
|  | SRCS=	net.example.in | ||||||
|  | INC=	net.example | ||||||
|  |  | ||||||
|  | MK=	../mk | ||||||
|  | include ${MK}/os.mk | ||||||
|  |  | ||||||
|  | %.example.in: %.example${SFX} | ||||||
|  | 	${CP} $< $@ | ||||||
|  |  | ||||||
|  | include ${MK}/scripts.mk | ||||||
							
								
								
									
										442
									
								
								doc/net.example.BSD.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										442
									
								
								doc/net.example.BSD.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,442 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # QUICK-START | ||||||
|  | # | ||||||
|  | # The quickest start is if you want to use DHCP. | ||||||
|  | # In that case, everything should work out of the box, no configuration | ||||||
|  | # necessary, though the startup script will warn you that you haven't | ||||||
|  | # specified anything. | ||||||
|  |  | ||||||
|  | # WARNING :- some examples have a mixture of IPv4 (ie 192.168.0.1) and IPv6 | ||||||
|  | # (ie 4321:0:1:2:3:4:567:89ab) internet addresses. They only work if you have | ||||||
|  | # the relevant kernel option enabled. So if you don't have an IPv6 enabled | ||||||
|  | # kernel then remove the IPv6 address from your config. | ||||||
|  |  | ||||||
|  | # If you want to use a static address or use DHCP explicitly, jump | ||||||
|  | # down to the section labeled INTERFACE HANDLERS. | ||||||
|  | # | ||||||
|  | # If you want to do anything more fancy, you should take the time to | ||||||
|  | # read through the rest of this file. | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # MODULES | ||||||
|  | # | ||||||
|  | # We now support modular networking scripts which means we can easily | ||||||
|  | # add support for new interface types and modules while keeping | ||||||
|  | # compatibility with existing ones. | ||||||
|  | # | ||||||
|  | # Modules load by default if the package they need is installed.  If | ||||||
|  | # you specify a module here that doesn't have its package installed | ||||||
|  | # then you get an error stating which package you need to install. | ||||||
|  | # Ideally, you only use the modules setting when you have two or more | ||||||
|  | # packages installed that supply the same service. | ||||||
|  | # | ||||||
|  | # In other words, you probably should DO NOTHING HERE... | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # INTERFACE HANDLERS | ||||||
|  |  | ||||||
|  | # For a static configuration, use something like this | ||||||
|  | #config_eth0="192.168.0.2/24" | ||||||
|  |  | ||||||
|  | # If you need more than one address, you can use something like this | ||||||
|  | # NOTE: ifconfig creates an aliased device for each extra IPv4 address | ||||||
|  | #       (eth0:1, eth0:2, etc) | ||||||
|  | #       iproute2 does not do this as there is no need to | ||||||
|  | #config_eth0="192.168.0.2/24 192.168.0.3/24 192.168.0.4/24" | ||||||
|  |  | ||||||
|  | # You can also use IPv6 addresses | ||||||
|  | # (you should always specify a prefix length with IPv6 here) | ||||||
|  | #config_eth0="192.168.0.2/24 4321:0:1:2:3:4:567:89ab/64 4321:0:1:2:3:4:567:89ac/64" | ||||||
|  |  | ||||||
|  | # If you wish to keep existing addresses + routing and the interface is up, | ||||||
|  | # you can specify a noop (no operation). If the interface is down or there | ||||||
|  | # are no addresses assigned, then we move onto the next step (default dhcp) | ||||||
|  | # This is useful when configuring your interface with a kernel command line | ||||||
|  | # or similar | ||||||
|  | #config_eth0="noop 192.168.0.2/24" | ||||||
|  |  | ||||||
|  | # If you don't want ANY address (only useful when calling for advanced stuff) | ||||||
|  | #config_eth0="null" | ||||||
|  |  | ||||||
|  | # Here's how to do routing if you need it | ||||||
|  | # We add an IPv4 default route, IPv4 subnet route and an IPv6 unicast route | ||||||
|  | #routes_eth0="default via 192.168.0.1 | ||||||
|  | #10.0.0.0/8 via 192.168.0.1 | ||||||
|  | #::/0" | ||||||
|  |  | ||||||
|  | # If a specified module fails (like dhcp - see below), you can specify a | ||||||
|  | # fallback like so | ||||||
|  | #fallback_eth0="192.168.0.2 netmask 255.255.255.0" | ||||||
|  | #fallback_routes_eth0="default via 192.168.0.1" | ||||||
|  |  | ||||||
|  | # NOTE: fallback entry must match the entry location in config_eth0 | ||||||
|  | # As such you can only have one fallback route. | ||||||
|  | # Also, if you do not set a fallback_routes entry for an interface, the | ||||||
|  | # routes entry will be used if that is set. | ||||||
|  |  | ||||||
|  | # Some users may need to alter the MTU - here's how | ||||||
|  | #mtu_eth0="1500" | ||||||
|  |  | ||||||
|  | # Most drivers that report carrier status function correctly, but some do not | ||||||
|  | # One of these faulty drivers is for the Intel e1000 network card, but only | ||||||
|  | # at boot time. To get around this you may alter the carrier_timeout value for | ||||||
|  | # the interface. -1 is disable, 0 is infinite and any other number of seconds | ||||||
|  | # is how long we wait for carrier. The current default is 3 seconds | ||||||
|  | #carrier_timeout_eth0=-1 | ||||||
|  |  | ||||||
|  | # You may wish to disable the interface being brought down when stopping. | ||||||
|  | # This is only of use for WakeOnLan. | ||||||
|  | #ifdown_eth0="NO" | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # OPTIONAL MODULES | ||||||
|  |  | ||||||
|  | #----------------------------------------------------------------------------- | ||||||
|  | # WIRELESS (802.11 support) | ||||||
|  | # Wireless can be provided by BSDs ifconfig (iwconfig) or wpa_supplicant | ||||||
|  | # wpa_supplicant is preferred, use the modules directive to prefer iwconfig. | ||||||
|  | #modules="iwconfig" | ||||||
|  |  | ||||||
|  | # ifconfig (iwconig) support is a one shot script - wpa_supplicant is daemon | ||||||
|  | # that scans, associates and re-configures if association is lost. | ||||||
|  | # We call it iwconfig to separate the wireless setup from ifconfig. | ||||||
|  | #################################### | ||||||
|  | # HINTS | ||||||
|  | # | ||||||
|  | # Most users will just need to set the following options | ||||||
|  | # key_SSID1="s:yourkeyhere enc open" # s: means a text key | ||||||
|  | # key_SSID2="aaaa-bbbb-cccc-dd"      # no s: means a hex key | ||||||
|  | # preferred_aps="SSID1 SSID2" | ||||||
|  | # | ||||||
|  | # Clear? Good. Now configure your wireless network below | ||||||
|  |  | ||||||
|  | #################################### | ||||||
|  | # SETTINGS | ||||||
|  | # Hard code an SSID to an interface - leave this unset if you wish the driver | ||||||
|  | # to scan for available Access Points | ||||||
|  | # I would only set this as a last resort really - use the preferred_aps | ||||||
|  | # setting at the bottom of this file | ||||||
|  | #essid_eth0='foo' | ||||||
|  |  | ||||||
|  | # Some drivers/hardware don't scan all that well. We have no control over this | ||||||
|  | # but we can say how many scans we want to do to try and get a better sweep of | ||||||
|  | # the area. The default is 1. | ||||||
|  | #scans_eth0="1" | ||||||
|  |  | ||||||
|  | #Channel can be set (1-14), but defaults to 3 if not set. | ||||||
|  | # | ||||||
|  | # The below is taken verbatim from the BSD wavelan documentation found at | ||||||
|  | # http://www.netbsd.org/Documentation/network/wavelan.html | ||||||
|  | # There are 14 channels possible; We are told that channels 1-11 are legal for | ||||||
|  | # North America, channels 1-13 for most of Europe, channels 10-13 for France, | ||||||
|  | # and only channel 14 for Japan. If in doubt, please refer to the documentation | ||||||
|  | # that came with your card or access point. Make sure that the channel you | ||||||
|  | # select is the same channel your access point (or the other card in an ad-hoc | ||||||
|  | # network) is on. The default for cards sold in North America and most of Europe | ||||||
|  | # is 3; the default for cards sold in France is 11, and the default for cards | ||||||
|  | # sold in Japan is 14. | ||||||
|  | #channel_eth0="3" | ||||||
|  |  | ||||||
|  | # Setup any other config commands. This is basically the ifconfig argument | ||||||
|  | # without the ifconfig $iface. | ||||||
|  | #ifconfig_eth0="" | ||||||
|  | # You can do the same per SSID too. | ||||||
|  | #ifconfig_SSID="" | ||||||
|  |  | ||||||
|  | # Seconds to wait until associated. The default is to wait 10 seconds. | ||||||
|  | # 0 means wait indefinitely. WARNING: this can cause an infinite delay when | ||||||
|  | # booting. | ||||||
|  | #associate_timeout_eth0="5" | ||||||
|  |  | ||||||
|  | # Define a WEP key per SSID or MAC address (of the AP, not your card) | ||||||
|  | # The encryption type (open or restricted) must match the | ||||||
|  | # encryption type on the Access Point. | ||||||
|  | # To set a hex key, prefix with 0x | ||||||
|  | #key_SSID="0x12341234123412341234123456" | ||||||
|  | # or you can use strings. Passphrase IS NOT supported | ||||||
|  | #key_SSID="foobar" | ||||||
|  | #key_SSID="foobar" | ||||||
|  |  | ||||||
|  | # WEP key for the AP with MAC address 001122334455 | ||||||
|  | #mac_key_001122334455="foobar" | ||||||
|  |  | ||||||
|  | # You can also override the interface settings found in /etc/conf.d/net | ||||||
|  | # per SSID - which is very handy if you use different networks a lot | ||||||
|  | #config_SSID="dhcp" | ||||||
|  | #routes_SSID= | ||||||
|  | #fallback_SSID= | ||||||
|  |  | ||||||
|  | # Setting name/domain server causes /etc/resolv.conf to be overwritten | ||||||
|  | # Note that if DHCP is used, and you want this to take precedence then | ||||||
|  | # please put -R in your dhcpcd options | ||||||
|  | #dns_servers_SSID="192.168.0.1 192.168.0.2" | ||||||
|  | #dns_domain_SSID="some.domain" | ||||||
|  | #dns_search_SSID="search.this.domain search.that.domain" | ||||||
|  | # Please check the man page for resolv.conf for more information | ||||||
|  | # as domain and search (searchdomains) are mutually exclusive and | ||||||
|  | # searchdomains takes precedence | ||||||
|  |  | ||||||
|  | # You can also set any of the /etc/conf.d/net variables per MAC address | ||||||
|  | # incase you use Access Points with the same SSID but need different | ||||||
|  | # networking configs. Below is an example - of course you use the same | ||||||
|  | # method with other variables | ||||||
|  | #config_001122334455="dhcp" | ||||||
|  | #dns_servers_001122334455="192.168.0.1 192.168.0.2" | ||||||
|  |  | ||||||
|  | # Map a MAC address to an SSID | ||||||
|  | # This is used when the Access Point is not broadcasting its SSID | ||||||
|  | # WARNING: This will override the SSID being broadcast due to some | ||||||
|  | # Access Points sending an SSID even when they have been configured | ||||||
|  | # not to! | ||||||
|  | # Change 001122334455 to the MAC address and SSID to the SSID | ||||||
|  | # it should map to | ||||||
|  | #mac_essid_001122334455="SSID" | ||||||
|  |  | ||||||
|  | # This lists the preferred SSIDs to connect to in order | ||||||
|  | # SSID's can contain any characters here as they must match the broadcast | ||||||
|  | # SSID exactly. | ||||||
|  | # Surround each SSID with the " character and separate them with a space | ||||||
|  | # If the first SSID isn't found then it moves onto the next | ||||||
|  | # If this isn't defined then it connects to the first one found | ||||||
|  | #preferred_aps="SSID1 SSID2" | ||||||
|  |  | ||||||
|  | # You can also define a preferred_aps list per interface | ||||||
|  | #preferred_aps_eth0="SSID3 SSID4" | ||||||
|  |  | ||||||
|  | # You can also say whether we only connect to preferred APs or not | ||||||
|  | # Values are "any", "preferredonly", "forcepreferred", "forcepreferredonly" | ||||||
|  | # and "forceany" | ||||||
|  | # "any" means it will connect to visible APs in the preferred list and then | ||||||
|  | # any other available AP | ||||||
|  | # "preferredonly" means it will only connect to visible APs in the preferred | ||||||
|  | # list | ||||||
|  | # "forcepreferred" means it will forcibly connect to APs in order if it does | ||||||
|  | # not find them in a scan | ||||||
|  | # "forcepreferredonly" means it forcibly connects to the APs in order and | ||||||
|  | # does not bother to scan | ||||||
|  | # "forceany" does the same as forcepreferred + connects to any other | ||||||
|  | # available AP | ||||||
|  | # Default is "any" | ||||||
|  | #associate_order="any" | ||||||
|  | #associate_order_eth0="any" | ||||||
|  |  | ||||||
|  | # You can define blacklisted Access Points in the same way | ||||||
|  | #blacklist_aps="SSID1 SSID2" | ||||||
|  | #blacklist_aps_eth0="SSID3 SSID4" | ||||||
|  |  | ||||||
|  | # If you have more than one wireless card, you can say if you want | ||||||
|  | # to allow each card to associate with the same Access Point or not | ||||||
|  | # Values are "yes" and "no" | ||||||
|  | # Default is "yes" | ||||||
|  | #unique_ap="yes" | ||||||
|  | #unique_ap_eth0="yes" | ||||||
|  |  | ||||||
|  | # IMPORTANT: preferred_only, blacklisted_aps and unique_ap only work when | ||||||
|  | # essid_eth0 is not set and your card is capable of scanning | ||||||
|  |  | ||||||
|  | # NOTE: preferred_aps  list ignores blacklisted_aps - so if you have | ||||||
|  | # the same SSID in both, well, you're a bit silly :p | ||||||
|  |  | ||||||
|  | ################################################## | ||||||
|  | # wpa_supplicant | ||||||
|  | # emerge net-wireless/wpa_supplicant | ||||||
|  | # Wireless options are held in /etc/wpa_supplicant/wpa_supplicant.conf | ||||||
|  | # Consult the wpa_supplicant.conf.example that is installed in | ||||||
|  | # /usr/share/doc/wpa_supplicant | ||||||
|  |  | ||||||
|  | # By default we don't wait for wpa_supplicant to associate and authenticate. | ||||||
|  | # If you would like to, so can specify how long in seconds | ||||||
|  | #associate_timeout_eth0=60 | ||||||
|  | # A value of 0 means wait forever. | ||||||
|  |  | ||||||
|  | # You can also override any settings found here per SSID - which is very | ||||||
|  | # handy if you use different networks a lot. See below for using the SSID | ||||||
|  | # in our variables | ||||||
|  | #config_SSID="dhcp" | ||||||
|  | # See the System module below for setting dns/nis/ntp per SSID | ||||||
|  |  | ||||||
|  | # You can also override any settings found here per MAC address of the AP | ||||||
|  | # in case you use Access Points with the same SSID but need different | ||||||
|  | # networking configs. Below is an example - of course you use the same | ||||||
|  | # method with other variables | ||||||
|  | #mac_config_001122334455="dhcp" | ||||||
|  | #mac_dns_servers_001122334455="192.168.0.1 192.168.0.2" | ||||||
|  |  | ||||||
|  | # When an interface has been associated with an Access Point, a global | ||||||
|  | # variable called SSID is set to the Access Point's SSID for use in the | ||||||
|  | # pre/post user functions below (although it's not available in preup as you | ||||||
|  | # won't have associated then) | ||||||
|  |  | ||||||
|  | # If you're using anything else to configure wireless on your interface AND | ||||||
|  | # you have installed wpa_supplicant, you need to disable wpa_supplicant | ||||||
|  | #modules="!iwconfig !wpa_supplicant" | ||||||
|  | #or | ||||||
|  | #modules="!wireless" | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # WIRELESS SSID IN VARIABLES | ||||||
|  | ############################################################################## | ||||||
|  | # Remember to change SSID to your SSID. | ||||||
|  | # Say that your SSID is My NET - the line | ||||||
|  | #      #key_SSID="s:passkey" | ||||||
|  | # becomes | ||||||
|  | #      #key_My_NET="s:passkey" | ||||||
|  | # Notice that the space has changed to an underscore - do the same with all | ||||||
|  | # characters not in a-z A-Z (English alphabet) 0-9. This only applies to | ||||||
|  | # variables and not values. | ||||||
|  | # | ||||||
|  | # Any SSID's in values like essid_eth0="My NET" may need to be escaped | ||||||
|  | # This means placing the character \ before the character | ||||||
|  | # \" need to be escaped for example | ||||||
|  | # So if your SSID is | ||||||
|  | #      My "\ NET | ||||||
|  | # it becomes | ||||||
|  | #      My \"\\ NET | ||||||
|  | # for example | ||||||
|  | #      #essid_eth0="My\"\\NET" | ||||||
|  | # | ||||||
|  | # So using the above we can use | ||||||
|  | #      #dns_domain_My____NET="My\"\\NET" | ||||||
|  | # which is an invalid dns domain, but shows the how to use the variable | ||||||
|  | # structure | ||||||
|  | ######################################################### | ||||||
|  |  | ||||||
|  | #----------------------------------------------------------------------------- | ||||||
|  | # DHCP | ||||||
|  | # DHCP can be provided by dhclient. | ||||||
|  | # | ||||||
|  | # dhcpcd:   emerge net-misc/dhcpcd | ||||||
|  | # dhclient: emerge net-misc/dhcp | ||||||
|  |  | ||||||
|  | # Regardless of which DHCP client you prefer, you configure them the | ||||||
|  | # same way using one of following depending on which interface modules | ||||||
|  | # you're using. | ||||||
|  | #config_eth0="dhcp" | ||||||
|  |  | ||||||
|  | # For passing custom options to dhcpcd use something like the following.  This | ||||||
|  | # example reduces the timeout for retrieving an address from 60 seconds (the | ||||||
|  | # default) to 10 seconds. | ||||||
|  | #dhcpcd_eth0="-t 10" | ||||||
|  |  | ||||||
|  | # GENERIC DHCP OPTIONS | ||||||
|  | # Set generic DHCP options like so | ||||||
|  | #dhcp_eth0="release nodns nontp nonis nogateway nosendhost" | ||||||
|  |  | ||||||
|  | # This tells the dhcp client to release its lease when it stops, not to | ||||||
|  | # overwrite dns, ntp and nis settings, not to set a default route and not to | ||||||
|  | # send the current hostname to the dhcp server and when it starts. | ||||||
|  | # You can use any combination of the above options - the default is not to | ||||||
|  | # use any of them. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #----------------------------------------------------------------------------- | ||||||
|  | # System | ||||||
|  | # For configuring system specifics such as domain, dns, ntp and nis servers | ||||||
|  | # It's rare that you would need todo this, but you can anyway. | ||||||
|  | # This is most benefit to wireless users who don't use DHCP so they can change | ||||||
|  | # their configs based on SSID. | ||||||
|  |  | ||||||
|  | # If you omit the _eth0 suffix, then it applies to all interfaces unless | ||||||
|  | # overridden by the interface suffix. | ||||||
|  | #dns_domain_eth0="your.domain" | ||||||
|  | #dns_servers_eth0="192.168.0.2 192.168.0.3" | ||||||
|  | #dns_search_eth0="this.domain that.domain" | ||||||
|  | #dns_options_eth0="timeout:1 rotate" | ||||||
|  | #dns_sortlist_eth0="130.155.160.0/255.255.240.0 130.155.0.0" | ||||||
|  | # See the man page for resolv.conf for details about the options and sortlist | ||||||
|  | # directives | ||||||
|  |  | ||||||
|  | #ntp_servers_eth0="192.168.0.2 192.168.0.3" | ||||||
|  |  | ||||||
|  | #nis_domain_eth0="domain" | ||||||
|  | #nis_servers_eth0="192.168.0.2 192.168.0.3" | ||||||
|  |  | ||||||
|  | # NOTE: Setting any of these will stamp on the files in question. So if you | ||||||
|  | # don't specify dns_servers but you do specify dns_domain then no nameservers | ||||||
|  | # will be listed in /etc/resolv.conf even if there were any there to start | ||||||
|  | # with. | ||||||
|  | # If this is an issue for you then maybe you should look into a resolv.conf | ||||||
|  | # manager like resolvconf-gentoo to manage this file for you. All packages | ||||||
|  | # that baselayout supports use resolvconf-gentoo if installed. | ||||||
|  |  | ||||||
|  | #----------------------------------------------------------------------------- | ||||||
|  | # Cable in/out detection | ||||||
|  | # Sometimes the cable is in, others it's out. Obviously you don't want to | ||||||
|  | # restart net.eth0 every time when you plug it in either. | ||||||
|  | # BSD has the Device State Change Daemon - or devd for short | ||||||
|  | # To enable this,  simple add devd to the boot runlevel | ||||||
|  | #rc-update add devd boot | ||||||
|  | #rc | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # ADVANCED CONFIGURATION | ||||||
|  | # | ||||||
|  | # Four functions can be defined which will be called surrounding the | ||||||
|  | # start/stop operations.  The functions are called with the interface | ||||||
|  | # name first so that one function can control multiple adapters. An extra two | ||||||
|  | # functions can be defined when an interface fails to start or stop. | ||||||
|  | # | ||||||
|  | # The return values for the preup and predown functions should be 0 | ||||||
|  | # (success) to indicate that configuration or deconfiguration of the | ||||||
|  | # interface can continue.  If preup returns a non-zero value, then | ||||||
|  | # interface configuration will be aborted.  If predown returns a | ||||||
|  | # non-zero value, then the interface will not be allowed to continue | ||||||
|  | # deconfiguration. | ||||||
|  | # | ||||||
|  | # The return values for the postup, postdown, failup and faildown functions are | ||||||
|  | # ignored since there's nothing to do if they indicate failure. | ||||||
|  | # | ||||||
|  | # ${IFACE} is set to the interface being brought up/down | ||||||
|  | # ${IFVAR} is ${IFACE} converted to variable name bash allows | ||||||
|  | # | ||||||
|  | # For historical and compatibility reasons, preup is actually normally called | ||||||
|  | # in the following sequence: up ; preup ; up. | ||||||
|  | # The first up causes the kernel to initialize the device, so | ||||||
|  | # that it is available for use in the preup function.  However, for some | ||||||
|  | # hardware, e.g. CAN devices, some configuration is needed before trying to up | ||||||
|  | # the interface will actually work. For such hardware, the | ||||||
|  | # up_before_preup variables will allow skipping the first up call if set | ||||||
|  | # to yes. | ||||||
|  | #up_before_preup_IFVAR="NO" | ||||||
|  | #up_before_preup="NO" | ||||||
|  |  | ||||||
|  | #preup() { | ||||||
|  | #	# Remember to return 0 on success | ||||||
|  | #	return 0 | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | #predown() { | ||||||
|  | #	# The default in the script is to test for NFS root and disallow | ||||||
|  | #	# downing interfaces in that case.  Note that if you specify a | ||||||
|  | #	# predown() function you will override that logic.  Here it is, in | ||||||
|  | #	# case you still want it... | ||||||
|  | #	if is_net_fs /; then | ||||||
|  | #		eerror "root filesystem is network mounted -- can't stop ${IFACE}" | ||||||
|  | #		return 1 | ||||||
|  | #	fi | ||||||
|  | # | ||||||
|  | #	# Remember to return 0 on success | ||||||
|  | #	return 0 | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | #postup() { | ||||||
|  | #	# This function could be used, for example, to register with a | ||||||
|  | #	# dynamic DNS service.  Another possibility would be to | ||||||
|  | #	# send/receive mail once the interface is brought up. | ||||||
|  |  | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | #postdown() { | ||||||
|  | #	# Return 0 always | ||||||
|  | #	return 0 | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | #failup() { | ||||||
|  | #       # This function is mostly here for completeness... I haven't | ||||||
|  | #       # thought of anything nifty to do with it yet ;-) | ||||||
|  | #} | ||||||
|  |  | ||||||
|  | #faildown() { | ||||||
|  | #       # This function is mostly here for completeness... I haven't | ||||||
|  | #       # thought of anything nifty to do with it yet ;-) | ||||||
|  | #} | ||||||
							
								
								
									
										1191
									
								
								doc/net.example.Linux.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1191
									
								
								doc/net.example.Linux.in
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										3
									
								
								etc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								etc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | rc.conf | ||||||
|  | rc | ||||||
|  | rc.shutdown | ||||||
							
								
								
									
										37
									
								
								etc/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								etc/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | DIR=	${SYSCONFDIR} | ||||||
|  | SRCS=	rc.conf.in rc.in rc.shutdown.in | ||||||
|  | BIN=	${BIN-${OS}} | ||||||
|  | CONF=	rc.conf ${BIN-${OS}} | ||||||
|  |  | ||||||
|  | CLEANFILES+=	rc.conf | ||||||
|  |  | ||||||
|  | MK=	../mk | ||||||
|  | include ${MK}/os.mk | ||||||
|  |  | ||||||
|  | SED_EXTRA-FreeBSD=	-e 's:@TERM@:cons25:g' | ||||||
|  | BIN-FreeBSD=		rc rc.shutdown rc.devd | ||||||
|  | CONF-FreeBSD=		devd.conf | ||||||
|  |  | ||||||
|  | SED_EXTRA-Linux=	-e 's:@TERM@:wsvt25:g' | ||||||
|  | BIN-Linux= | ||||||
|  | CONF-Linux= | ||||||
|  |  | ||||||
|  | SED_EXTRA-NetBSD=	-e 's:@TERM@:wsvt25:g' | ||||||
|  | BIN-NetBSD=		rc rc.shutdown | ||||||
|  | CONF-NetBSD= | ||||||
|  |  | ||||||
|  | SED_EXTRA=	${SED_EXTRA-${OS}} | ||||||
|  |  | ||||||
|  | include ${MK}/scripts.mk | ||||||
|  |  | ||||||
|  | # We can't use "ifndef" here because that treats set-but-empty | ||||||
|  | # as not-set which is not what we want | ||||||
|  | MKRCSYS ?= automagicplease | ||||||
|  | ifeq (${MKRCSYS},automagicplease) | ||||||
|  | # If the user isn't picking a default, then have the | ||||||
|  | # config go with runtime automagic detection #357247 | ||||||
|  | rc.conf: SED_EXTRA += -e '/^rc_sys=""/s:^:\#:' | ||||||
|  | MKRCSYS = | ||||||
|  | endif | ||||||
|  | rc.conf: rc.conf.in rc.conf.${OS} | ||||||
|  | 	${SED} ${SED_REPLACE} ${SED_EXTRA} $^ > $@ | ||||||
| @@ -1,44 +0,0 @@ | |||||||
| etc_conf_data = configuration_data() |  | ||||||
| if os == 'FreeBSD' |  | ||||||
|   etc_conf_data.set('TERM', 'cons25') |  | ||||||
| elif os == 'Linux' |  | ||||||
|   etc_conf_data.set('TERM', 'wsvt25') |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| etc_conf_common = [ |  | ||||||
|   'rc.conf', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| etc_bin_FreeBSD = [ |  | ||||||
|   'rc.devd', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| etc_conf_FreeBSD = [ |  | ||||||
|   'devd.conf', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| etc_bin_NetBSD =  [ |  | ||||||
|   'rc.in', |  | ||||||
|   'rc.shutdown.in', |  | ||||||
|   ] |  | ||||||
|  |  | ||||||
| install_data(etc_conf_common, |  | ||||||
|   install_dir : get_option('sysconfdir')) |  | ||||||
|  |  | ||||||
|   if os == 'FreeBSD' |  | ||||||
|   install_data(etc_bin_FreeBSD, |  | ||||||
|     install_dir : get_option('sysconfdir'), |  | ||||||
|     install_mode: 'rwxr-xr-x') |  | ||||||
|   install_data(etc_conf_FreeBSD, |  | ||||||
|     install_dir : get_option('sysconfdir')) |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| if os == 'FreeBSD' or os == 'NetBSD' |  | ||||||
|   foreach file : etc_bin_NetBSD |  | ||||||
|     configure_file(input : file, |  | ||||||
|       output : '@BASENAME@', |  | ||||||
|       configuration : etc_conf_data, |  | ||||||
|       install_dir: get_option('sysconfdir'), |  | ||||||
|       install_mode: 'rwxr-xr-x') |  | ||||||
|   endforeach |  | ||||||
| endif |  | ||||||
							
								
								
									
										317
									
								
								etc/rc.conf
									
									
									
									
									
								
							
							
						
						
									
										317
									
								
								etc/rc.conf
									
									
									
									
									
								
							| @@ -1,317 +0,0 @@ | |||||||
| # Global OpenRC configuration settings |  | ||||||
|  |  | ||||||
| # Set to "YES" if you want the rc system to try and start services |  | ||||||
| # in parallel for a slight speed improvement. When running in parallel we |  | ||||||
| # prefix the service output with its name as the output will get |  | ||||||
| # jumbled up. |  | ||||||
| # WARNING: whilst we have improved parallel, it can still potentially lock |  | ||||||
| # the boot process. Don't file bugs about this unless you can supply |  | ||||||
| # patches that fix it without breaking other things! |  | ||||||
| #rc_parallel="NO" |  | ||||||
|  |  | ||||||
| # Set rc_interactive to "YES" and you'll be able to press the I key during |  | ||||||
| # boot so you can choose to start specific services. Set to "NO" to disable |  | ||||||
| # this feature. This feature is automatically disabled if rc_parallel is |  | ||||||
| # set to YES. |  | ||||||
| #rc_interactive="YES" |  | ||||||
|  |  | ||||||
| # If we need to drop to a shell, you can specify it here. |  | ||||||
| # If not specified we use $SHELL, otherwise the one specified in /etc/passwd, |  | ||||||
| # otherwise /bin/sh |  | ||||||
| # Linux users could specify /sbin/sulogin |  | ||||||
| #rc_shell=/bin/sh |  | ||||||
|  |  | ||||||
| # Do we allow any started service in the runlevel to satisfy the dependency |  | ||||||
| # or do we want all of them regardless of state? For example, if net.eth0 |  | ||||||
| # and net.eth1 are in the default runlevel then with rc_depend_strict="NO" |  | ||||||
| # both will be started, but services that depend on 'net' will work if either |  | ||||||
| # one comes up. With rc_depend_strict="YES" we would require them both to |  | ||||||
| # come up. |  | ||||||
| #rc_depend_strict="YES" |  | ||||||
|  |  | ||||||
| # rc_hotplug controls which services we allow to be hotplugged. |  | ||||||
| # A hotplugged service is one started by a dynamic dev manager when a matching |  | ||||||
| # hardware device is found. |  | ||||||
| # Hotplugged services appear in the "hotplugged" runlevel. |  | ||||||
| # If rc_hotplug is set to any value, we compare the name of this service |  | ||||||
| # to every pattern in the value, from left to right, and we allow the |  | ||||||
| # service to be hotplugged if it matches a pattern, or if it matches no |  | ||||||
| # patterns. Patterns can include shell wildcards. |  | ||||||
| # To disable services from being hotplugged, prefix patterns with "!". |  | ||||||
| #If rc_hotplug is not set or is empty, all hotplugging is disabled. |  | ||||||
| # Example - rc_hotplug="net.wlan !net.*" |  | ||||||
| # This allows net.wlan and any service not matching net.* to be hotplugged. |  | ||||||
| # Example - rc_hotplug="!net.*" |  | ||||||
| # This allows services that do not match "net.*" to be hotplugged. |  | ||||||
|  |  | ||||||
| # rc_logger launches a logging daemon to log the entire rc process to |  | ||||||
| # /var/log/rc.log |  | ||||||
| # NOTE: Linux systems require the devfs service to be started before |  | ||||||
| # logging can take place and as such cannot log the sysinit runlevel. |  | ||||||
| #rc_logger="NO" |  | ||||||
|  |  | ||||||
| # Through rc_log_path you can specify a custom log file. |  | ||||||
| # The default value is: /var/log/rc.log |  | ||||||
| #rc_log_path="/var/log/rc.log" |  | ||||||
|  |  | ||||||
| # If you want verbose output for OpenRC, set this to yes. If you want |  | ||||||
| # verbose output for service foo only, set it to yes in /etc/conf.d/foo. |  | ||||||
| #rc_verbose=no |  | ||||||
|  |  | ||||||
| # By default we filter the environment for our running scripts. To allow other |  | ||||||
| # variables through, add them here. Use a * to allow all variables through. |  | ||||||
| #rc_env_allow="VAR1 VAR2" |  | ||||||
|  |  | ||||||
| # By default we assume that all daemons will start correctly. |  | ||||||
| # However, some do not - a classic example is that they fork and return 0 AND |  | ||||||
| # then child barfs on a configuration error. Or the daemon has a bug and the |  | ||||||
| # child crashes. You can set the number of milliseconds start-stop-daemon |  | ||||||
| # waits to check that the daemon is still running after starting here. |  | ||||||
| # The default is 0 - no checking. |  | ||||||
| #rc_start_wait=100 |  | ||||||
|  |  | ||||||
| # rc_nostop is a list of services which will not stop when changing runlevels. |  | ||||||
| # This still allows the service itself to be stopped when called directly. |  | ||||||
| #rc_nostop="" |  | ||||||
|  |  | ||||||
| # rc will attempt to start crashed services by default. |  | ||||||
| # However, it will not stop them by default as that could bring down other |  | ||||||
| # critical services. |  | ||||||
| #rc_crashed_stop=NO |  | ||||||
| #rc_crashed_start=YES |  | ||||||
|  |  | ||||||
| # Set rc_nocolor to yes if you do not want colors displayed in OpenRC |  | ||||||
| # output. |  | ||||||
| #rc_nocolor=NO |  | ||||||
|  |  | ||||||
| ############################################################################## |  | ||||||
| # MISC CONFIGURATION VARIABLES |  | ||||||
| # There variables are shared between many init scripts |  | ||||||
|  |  | ||||||
| # Set unicode to YES to turn on unicode support for keyboards and screens. |  | ||||||
| #unicode="NO" |  | ||||||
|  |  | ||||||
| # This is how long fuser should wait for a remote server to respond. The |  | ||||||
| # default is 60 seconds, but  it can be adjusted here. |  | ||||||
| #rc_fuser_timeout=60 |  | ||||||
|  |  | ||||||
| # Below is the default list of network fstypes. |  | ||||||
| # |  | ||||||
| # afs ceph cifs coda davfs fuse fuse.glusterfs fuse.sshfs gfs glusterfs lustre |  | ||||||
| # ncpfs nfs nfs4 ocfs2 shfs smbfs |  | ||||||
| # |  | ||||||
| # If you would like to add to this list, you can do so by adding your |  | ||||||
| # own fstypes to the following variable. |  | ||||||
| #extra_net_fs_list="" |  | ||||||
|  |  | ||||||
| ############################################################################## |  | ||||||
| # SERVICE CONFIGURATION VARIABLES |  | ||||||
| # These variables are documented here, but should be configured in |  | ||||||
| # /etc/conf.d/foo for service foo and NOT enabled here unless you |  | ||||||
| # really want them to work on a global basis. |  | ||||||
| # If your service has characters in its name which are not legal in |  | ||||||
| # shell variable names and you configure the variables for it in this |  | ||||||
| # file, those characters should be replaced with underscores in the |  | ||||||
| # variable names as shown below. |  | ||||||
|  |  | ||||||
| # Some daemons are started and stopped via start-stop-daemon. |  | ||||||
| # We can set some things on a per service basis, like the nicelevel. |  | ||||||
| #SSD_NICELEVEL="0" |  | ||||||
| # Or the ionice level. The format is class[:data] , just like the |  | ||||||
| # --ionice start-stop-daemon parameter. |  | ||||||
| #SSD_IONICELEVEL="0:0" |  | ||||||
| # Or the OOM score adjustment. |  | ||||||
| #SSD_OOM_SCORE_ADJ="0" |  | ||||||
|  |  | ||||||
| # Pass ulimit parameters |  | ||||||
| # If you are using bash in POSIX mode for your shell, note that the |  | ||||||
| # ulimit command uses a block size of 512 bytes for the -c and -f |  | ||||||
| # options |  | ||||||
| #rc_ulimit="-u 30" |  | ||||||
|  |  | ||||||
| # It's possible to define extra dependencies for services like so |  | ||||||
| #rc_config="/etc/foo" |  | ||||||
| #rc_need="openvpn" |  | ||||||
| #rc_use="net.eth0" |  | ||||||
| #rc_after="clock" |  | ||||||
| #rc_before="local" |  | ||||||
| #rc_provide="!net" |  | ||||||
|  |  | ||||||
| # You can also enable the above commands here for each service. Below is an |  | ||||||
| # example for service foo. |  | ||||||
| #rc_foo_config="/etc/foo" |  | ||||||
| #rc_foo_need="openvpn" |  | ||||||
| #rc_foo_after="clock" |  | ||||||
|  |  | ||||||
| # Below is an example for service foo-bar. Note that the '-' is illegal |  | ||||||
| # in a shell variable name, so we convert it to an underscore. |  | ||||||
| # example for service foo-bar. |  | ||||||
| #rc_foo_bar_config="/etc/foo-bar" |  | ||||||
| #rc_foo_bar_need="openvpn" |  | ||||||
| #rc_foo_bar_after="clock" |  | ||||||
|  |  | ||||||
| # You can also remove dependencies. |  | ||||||
| # This is mainly used for saying which services do NOT provide net. |  | ||||||
| #rc_net_tap0_provide="!net" |  | ||||||
|  |  | ||||||
| # This is the subsystem type. |  | ||||||
| # It is used to match against keywords set by the keyword call in the |  | ||||||
| # depend function of service scripts. |  | ||||||
| # |  | ||||||
| # It should be set to the value representing the environment this file is |  | ||||||
| # PRESENTLY in, not the virtualization the environment is capable of. |  | ||||||
| # If it is commented out, automatic detection will be used. |  | ||||||
| # |  | ||||||
| # The list below shows all possible settings as well as the host |  | ||||||
| # operating systems where they can be used and autodetected. |  | ||||||
| # |  | ||||||
| # ""               - nothing special |  | ||||||
| # "docker"         - Docker container manager (Linux) |  | ||||||
| # "jail"           - Jail (DragonflyBSD or FreeBSD) |  | ||||||
| # "lxc"            - Linux Containers |  | ||||||
| # "openvz"         - Linux OpenVZ |  | ||||||
| # "prefix"         - Prefix |  | ||||||
| # "rkt"            - CoreOS container management system (Linux) |  | ||||||
| # "subhurd"        - Hurd subhurds (to be checked) |  | ||||||
| # "systemd-nspawn" - Container created by systemd-nspawn (Linux) |  | ||||||
| # "uml"            - Usermode Linux |  | ||||||
| # "vserver"        - Linux vserver |  | ||||||
| # "xen0"           - Xen0 Domain (Linux and NetBSD) |  | ||||||
| # "xenU"           - XenU Domain (Linux and NetBSD) |  | ||||||
| #rc_sys="" |  | ||||||
|  |  | ||||||
| # if  you use openrc-init, which is currently only available on Linux, |  | ||||||
| # this is the default runlevel to activate after "sysinit" and "boot" |  | ||||||
| # when booting. |  | ||||||
| #rc_default_runlevel="default" |  | ||||||
|  |  | ||||||
| # on Linux and Hurd, this is the number of ttys allocated for logins |  | ||||||
| # It is used in the consolefont, keymaps, numlock and termencoding |  | ||||||
| # service scripts. |  | ||||||
| rc_tty_number=12 |  | ||||||
|  |  | ||||||
| ############################################################################## |  | ||||||
| # LINUX CGROUPS RESOURCE MANAGEMENT |  | ||||||
|  |  | ||||||
| # This sets the mode used to mount cgroups. |  | ||||||
| # "hybrid" mounts cgroups version 2 on /sys/fs/cgroup/unified and |  | ||||||
| # cgroups version 1 on /sys/fs/cgroup. |  | ||||||
| # "legacy" mounts cgroups version 1 on /sys/fs/cgroup |  | ||||||
| # "unified" mounts cgroups version 2 on /sys/fs/cgroup |  | ||||||
| #rc_cgroup_mode="hybrid" |  | ||||||
|  |  | ||||||
| # This is a list of controllers which should be enabled for cgroups version 2 |  | ||||||
| # when hybrid mode is being used. |  | ||||||
| # Controllers listed here will not be available for cgroups version 1. |  | ||||||
| #rc_cgroup_controllers="" |  | ||||||
|  |  | ||||||
| # This variable contains the cgroups version 2 settings for your services. |  | ||||||
| # If this is set in this file, the settings will apply to all services. |  | ||||||
| # If you want different settings for each service, place the settings in |  | ||||||
| # /etc/conf.d/foo for service foo. |  | ||||||
| # The format is to specify the setting and value followed by a newline. |  | ||||||
| # Multiple settings and values can be specified. |  | ||||||
| # For example, you would use this to set the maximum memory and maximum |  | ||||||
| # number of pids for a service. |  | ||||||
| #rc_cgroup_settings=" |  | ||||||
| #memory.max 10485760 |  | ||||||
| #pids.max max |  | ||||||
| #" |  | ||||||
| # |  | ||||||
| # For more information about the adjustments that can be made with |  | ||||||
| # cgroups version 2, see Documentation/cgroups-v2.txt in the linux kernel |  | ||||||
| # source tree. |  | ||||||
| #rc_cgroup_settings="" |  | ||||||
|  |  | ||||||
| # This switch controls whether or not cgroups version 1 controllers are |  | ||||||
| # individually mounted under |  | ||||||
| # /sys/fs/cgroup in hybrid or legacy mode. |  | ||||||
| #rc_controller_cgroups="YES" |  | ||||||
|  |  | ||||||
| # The following setting turns on the memory.use_hierarchy setting in the |  | ||||||
| # root memory cgroup for cgroups v1. |  | ||||||
| # It must be set to yes in this file if you want this functionality. |  | ||||||
| #rc_cgroup_memory_use_hierarchy="NO" |  | ||||||
|  |  | ||||||
| # The following settings allow you to set up values for the cgroups version 1 |  | ||||||
| # controllers for your services. |  | ||||||
| # They can be set in this file;, however, if you do this, the settings |  | ||||||
| # will apply to all of your services. |  | ||||||
| # If you want different settings for each service, place the settings in |  | ||||||
| # /etc/conf.d/foo for service foo. |  | ||||||
| # The format is to specify the names of the settings followed by their |  | ||||||
| # values. Each variable can hold multiple settings. |  | ||||||
| # For example, you would use this to set the cpu.shares setting in the |  | ||||||
| # cpu controller to 512 for your service. |  | ||||||
| # rc_cgroup_cpu=" |  | ||||||
| # cpu.shares 512 |  | ||||||
| # " |  | ||||||
| # |  | ||||||
| # For more information about the adjustments that can be made with |  | ||||||
| # cgroups version 1, see Documentation/cgroups-v1/* in the linux kernel |  | ||||||
| # source tree. |  | ||||||
|  |  | ||||||
| # Set the blkio controller settings for this service. |  | ||||||
| #rc_cgroup_blkio="" |  | ||||||
|  |  | ||||||
| # Set the cpu controller settings for this service. |  | ||||||
| #rc_cgroup_cpu="" |  | ||||||
|  |  | ||||||
| # Add this service to the cpuacct controller (any value means yes). |  | ||||||
| #rc_cgroup_cpuacct="" |  | ||||||
|  |  | ||||||
| # Set the cpuset controller settings for this service. |  | ||||||
| #rc_cgroup_cpuset="" |  | ||||||
|  |  | ||||||
| # Set the devices controller settings for this service. |  | ||||||
| #rc_cgroup_devices="" |  | ||||||
|  |  | ||||||
| # Set the hugetlb controller settings for this service. |  | ||||||
| #rc_cgroup_hugetlb="" |  | ||||||
|  |  | ||||||
| # Set the memory controller settings for this service. |  | ||||||
| #rc_cgroup_memory="" |  | ||||||
|  |  | ||||||
| # Set the net_cls controller settings for this service. |  | ||||||
| #rc_cgroup_net_cls="" |  | ||||||
|  |  | ||||||
| # Set the net_prio controller settings for this service. |  | ||||||
| #rc_cgroup_net_prio="" |  | ||||||
|  |  | ||||||
| # Set the pids controller settings for this service. |  | ||||||
| #rc_cgroup_pids="" |  | ||||||
|  |  | ||||||
| # Set this to YES if you want all of the processes in a service's cgroup |  | ||||||
| # killed when the service is stopped or restarted. |  | ||||||
| # Be aware that setting this to yes means all of a service's |  | ||||||
| # child processes will be killed. Keep this in mind if you set this to |  | ||||||
| # yes here instead of for the individual services in |  | ||||||
| # /etc/conf.d/<service>. |  | ||||||
| # To perform this cleanup manually for a stopped service, you can |  | ||||||
| # execute cgroup_cleanup with /etc/init.d/<service> cgroup_cleanup or |  | ||||||
| # rc-service <service> cgroup_cleanup. |  | ||||||
| # If the kernel includes support for cgroup2's cgroup.kill, this is used |  | ||||||
| # to reliably teardown the cgroup. |  | ||||||
| # If this fails, the process followed in this cleanup is the following: |  | ||||||
| # 1. send stopsig (sigterm if it isn't set) to all processes left in the |  | ||||||
| # cgroup immediately followed by sigcont. |  | ||||||
| # 2. Send sighup to all processes in the cgroup if rc_send_sighup is |  | ||||||
| # yes. |  | ||||||
| # 3. delay for rc_timeout_stopsec seconds. |  | ||||||
| # 4. send sigkill to all processes in the cgroup unless disabled by |  | ||||||
| # setting rc_send_sigkill to no. |  | ||||||
| # rc_cgroup_cleanup="NO" |  | ||||||
|  |  | ||||||
| # If this is yes, we will send sighup to the processes in the cgroup |  | ||||||
| # immediately after stopsig and sigcont. |  | ||||||
| #rc_send_sighup="NO" |  | ||||||
|  |  | ||||||
| # This is the amount of time in seconds that we delay after sending sigcont |  | ||||||
| # and optionally sighup, before we optionally send sigkill to all |  | ||||||
| # processes in the # cgroup. |  | ||||||
| # The default is 90 seconds. |  | ||||||
| #rc_timeout_stopsec="90" |  | ||||||
|  |  | ||||||
| # If this is set to no, we do not send sigkill to all processes in the |  | ||||||
| # cgroup. |  | ||||||
| #rc_send_sigkill="YES" |  | ||||||
							
								
								
									
										14
									
								
								etc/rc.conf.FreeBSD
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								etc/rc.conf.FreeBSD
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # FreeBSD SPECIFIC OPTIONS | ||||||
|  |  | ||||||
|  | # This is the subsystem type. Valid options on FreeBSD: | ||||||
|  | # ""        - nothing special | ||||||
|  | # "jail"    - FreeBSD jails | ||||||
|  | # "prefix"  - Prefix | ||||||
|  | # If this is commented out, automatic detection will be attempted. | ||||||
|  | # Note that automatic detection does not work in a prefix environment. | ||||||
|  | # | ||||||
|  | # This should be set to the value representing the environment this file is | ||||||
|  | # PRESENTLY in, not the virtualization the environment is capable of. | ||||||
|  | rc_sys="@RC_SYS_DEFAULT@" | ||||||
|  |  | ||||||
							
								
								
									
										23
									
								
								etc/rc.conf.Linux
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								etc/rc.conf.Linux
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # LINUX SPECIFIC OPTIONS | ||||||
|  |  | ||||||
|  | # This is the subsystem type. Valid options on Linux: | ||||||
|  | # ""        - nothing special | ||||||
|  | # "lxc"     - Linux Containers | ||||||
|  | # "openvz"  - Linux OpenVZ | ||||||
|  | # "prefix"  - Prefix | ||||||
|  | # "uml"     - Usermode Linux | ||||||
|  | # "vserver" - Linux vserver | ||||||
|  | # "xen0"    - Xen0 Domain | ||||||
|  | # "xenU"    - XenU Domain | ||||||
|  | # If this is commented out, automatic detection will be attempted. | ||||||
|  | # Note that autodetection will not work in a prefix environment or in a | ||||||
|  | # linux container. | ||||||
|  | # | ||||||
|  | # This should be set to the value representing the environment this file is | ||||||
|  | # PRESENTLY in, not the virtualization the environment is capable of. | ||||||
|  | rc_sys="@RC_SYS_DEFAULT@" | ||||||
|  |  | ||||||
|  | # This is the number of tty's used in most of the rc-scripts (like | ||||||
|  | # consolefont, numlock, etc ...) | ||||||
|  | rc_tty_number=12 | ||||||
							
								
								
									
										15
									
								
								etc/rc.conf.NetBSD
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								etc/rc.conf.NetBSD
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | ############################################################################## | ||||||
|  | # NetBSD SPECIFIC OPTIONS | ||||||
|  |  | ||||||
|  | # This is the subsystem type. Valid options on NetBSD: | ||||||
|  | # ""        - nothing special | ||||||
|  | # "prefix"  - Prefix | ||||||
|  | # "xen0"    - Xen0 Domain | ||||||
|  | # "xenU"    - XenU Domain | ||||||
|  | # If this is commented out, automatic detection will be attempted. | ||||||
|  | # Note that automatic detection does not work in a prefix environment. | ||||||
|  | # | ||||||
|  | # This should be set to the value representing the environment this file is | ||||||
|  | # PRESENTLY in, not the virtualization the environment is capable of. | ||||||
|  | rc_sys="@RC_SYS_DEFAULT@" | ||||||
|  |  | ||||||
							
								
								
									
										112
									
								
								etc/rc.conf.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								etc/rc.conf.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,112 @@ | |||||||
|  | # Global OpenRC configuration settings | ||||||
|  |  | ||||||
|  | # Set rc_interactive to "YES" and you'll be able to press the I key during | ||||||
|  | # boot so you can choose to start specific services. Set to "NO" to disable | ||||||
|  | # this feature. | ||||||
|  | #rc_interactive="YES" | ||||||
|  |  | ||||||
|  | # If we need to drop to a shell, you can specify it here. | ||||||
|  | # If not specified we use $SHELL, otherwise the one specified in /etc/passwd, | ||||||
|  | # otherwise /bin/sh | ||||||
|  | # Linux users could specify /sbin/sulogin | ||||||
|  | #rc_shell=/bin/sh | ||||||
|  |  | ||||||
|  | # Do we allow any started service in the runlevel to satisfy the dependency | ||||||
|  | # or do we want all of them regardless of state? For example, if net.eth0 | ||||||
|  | # and net.eth1 are in the default runlevel then with rc_depend_strict="NO" | ||||||
|  | # both will be started, but services that depend on 'net' will work if either | ||||||
|  | # one comes up. With rc_depend_strict="YES" we would require them both to | ||||||
|  | # come up. | ||||||
|  | #rc_depend_strict="YES" | ||||||
|  |  | ||||||
|  | # rc_hotplug is a list of services that we allow to be hotplugged. | ||||||
|  | # By default we do not allow hotplugging. | ||||||
|  | # A hotplugged service is one started by a dynamic dev manager when a matching | ||||||
|  | # hardware device is found. | ||||||
|  | # This service is intrinsically included in the boot runlevel. | ||||||
|  | # To disable services, prefix with a ! | ||||||
|  | # Example - rc_hotplug="net.wlan !net.*" | ||||||
|  | # This allows net.wlan and any service not matching net.* to be plugged. | ||||||
|  | # Example - rc_hotplug="*" | ||||||
|  | # This allows all services to be hotplugged | ||||||
|  | #rc_hotplug="*" | ||||||
|  |  | ||||||
|  | # rc_logger launches a logging daemon to log the entire rc process to | ||||||
|  | # /var/log/rc.log | ||||||
|  | # NOTE: Linux systems require the devfs service to be started before | ||||||
|  | # logging can take place and as such cannot log the sysinit runlevel. | ||||||
|  | #rc_logger="YES" | ||||||
|  |  | ||||||
|  | # Through rc_log_path you can specify a custom log file. | ||||||
|  | # The default value is: /var/log/rc.log | ||||||
|  | #rc_log_path="/var/log/rc.log" | ||||||
|  |  | ||||||
|  | # By default we filter the environment for our running scripts. To allow other | ||||||
|  | # variables through, add them here. Use a * to allow all variables through. | ||||||
|  | #rc_env_allow="VAR1 VAR2" | ||||||
|  |  | ||||||
|  | # By default we assume that all daemons will start correctly. | ||||||
|  | # However, some do not - a classic example is that they fork and return 0 AND | ||||||
|  | # then child barfs on a configuration error. Or the daemon has a bug and the | ||||||
|  | # child crashes. You can set the number of milliseconds start-stop-daemon | ||||||
|  | # waits to check that the daemon is still running after starting here. | ||||||
|  | # The default is 0 - no checking. | ||||||
|  | #rc_start_wait=100 | ||||||
|  |  | ||||||
|  | # rc_nostop is a list of services which will not stop when changing runlevels. | ||||||
|  | # This still allows the service itself to be stopped when called directly. | ||||||
|  | #rc_nostop="" | ||||||
|  |  | ||||||
|  | # rc will attempt to start crashed services by default. | ||||||
|  | # However, it will not stop them by default as that could bring down other | ||||||
|  | # critical services. | ||||||
|  | #rc_crashed_stop=NO | ||||||
|  | #rc_crashed_start=YES | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # MISC CONFIGURATION VARIABLES | ||||||
|  | # There variables are shared between many init scripts | ||||||
|  |  | ||||||
|  | # Set unicode to YES to turn on unicode support for keyboards and screens. | ||||||
|  | #unicode="NO" | ||||||
|  |  | ||||||
|  | # Below is the default list of network fstypes. | ||||||
|  | # | ||||||
|  | # afs cifs coda davfs fuse fuse.sshfs gfs glusterfs lustre ncpfs | ||||||
|  | # nfs nfs4 ocfs2 shfs smbfs | ||||||
|  | # | ||||||
|  | # If you would like to add to this list, you can do so by adding your | ||||||
|  | # own fstypes to the following variable. | ||||||
|  | #extra_net_fs_list="" | ||||||
|  |  | ||||||
|  | ############################################################################## | ||||||
|  | # SERVICE CONFIGURATION VARIABLES | ||||||
|  | # These variables are documented here, but should be configured in | ||||||
|  | # /etc/conf.d/foo for service foo and NOT enabled here unless you | ||||||
|  | # really want them to work on a global basis. | ||||||
|  |  | ||||||
|  | # Some daemons are started and stopped via start-stop-daemon. | ||||||
|  | # We can set some things on a per service basis, like the nicelevel. | ||||||
|  | #export SSD_NICELEVEL="-19" | ||||||
|  |  | ||||||
|  | # Pass ulimit parameters | ||||||
|  | #rc_ulimit="-u 30" | ||||||
|  |  | ||||||
|  | # It's possible to define extra dependencies for services like so | ||||||
|  | #rc_config="/etc/foo" | ||||||
|  | #rc_need="openvpn" | ||||||
|  | #rc_use="net.eth0" | ||||||
|  | #rc_after="clock" | ||||||
|  | #rc_before="local" | ||||||
|  | #rc_provide="!net" | ||||||
|  |  | ||||||
|  | # You can also enable the above commands here for each service. Below is an | ||||||
|  | # example for service foo. | ||||||
|  | #rc_foo_config="/etc/foo" | ||||||
|  | #rc_foo_need="openvpn" | ||||||
|  | #rc_foo_after="clock" | ||||||
|  |  | ||||||
|  | # You can also remove dependencies. | ||||||
|  | # This is mainly used for saying which servies do NOT provide net. | ||||||
|  | #rc_net_tap0_provide="!net" | ||||||
|  |  | ||||||
							
								
								
									
										18
									
								
								etc/rc.devd
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								etc/rc.devd
									
									
									
									
									
								
							| @@ -1,18 +1,10 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| #    except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # Inform RC that we are in the background and hotplugged | # Inform RC that we are in the background and hotplugged | ||||||
| IN_BACKGROUND=yes | export IN_BACKGROUND=yes | ||||||
| IN_HOTPLUG=yes | export IN_HOTPLUG=yes | ||||||
| export IN_BACKGROUND IN_HOTPLUG |  | ||||||
|  |  | ||||||
| getmedia() { | getmedia() { | ||||||
| 	ifconfig "$1" | while read line; do | 	ifconfig "$1" | while read line; do | ||||||
| @@ -26,7 +18,7 @@ getmedia() { | |||||||
| if [ ! -e /etc/init.d/"$1" -a ! -e /usr/local/init.d/"$1" ]; then | if [ ! -e /etc/init.d/"$1" -a ! -e /usr/local/init.d/"$1" ]; then | ||||||
| 	base=${1%%.*} | 	base=${1%%.*} | ||||||
| 	if [ "${base}" = "net" ]; then | 	if [ "${base}" = "net" ]; then | ||||||
| 		# We only create links for physical interfaces | 		# We only create links for pyhsical interfaces | ||||||
| 		[ -n "$(getmedia ${1#*.})" ] || exit 1 | 		[ -n "$(getmedia ${1#*.})" ] || exit 1 | ||||||
| 		base="net.lo0" | 		base="net.lo0" | ||||||
| 	fi | 	fi | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								etc/rc.in
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								etc/rc.in
									
									
									
									
									
								
							| @@ -1,25 +1,18 @@ | |||||||
| #!/bin/sh | #!@SHELL@ | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| #    except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # If $TERM is not set then assume default of @TERM@ | # If $TERM is not set then assume default of @TERM@ | ||||||
| # This gives us a nice colour boot :) | # This gives us a nice colour boot :) | ||||||
| [ -z "$TERM" -o "$TERM" = "dumb" ] && TERM="@TERM@" && export TERM | [ -z "$TERM" -o "$TERM" = "dumb" ] && export TERM="@TERM@" | ||||||
|  |  | ||||||
| # Handle interrupts | # Handle interrupts | ||||||
| trap : SIGINT | trap : SIGINT | ||||||
| trap "echo 'Boot interrupted'; exit 1" SIGQUIT | trap "echo 'Boot interrupted'; exit 1" SIGQUIT | ||||||
|  |  | ||||||
| /sbin/openrc sysinit || exit 1 | /sbin/rc sysinit || exit 1 | ||||||
| /sbin/openrc boot || exit 1 | /sbin/rc boot || exit 1 | ||||||
| /sbin/openrc default | /sbin/rc default | ||||||
|  |  | ||||||
| # We don't actually care if rc default worked or not, we should exit 0 | # We don't actually care if rc default worked or not, we should exit 0 | ||||||
| # to allow logins | # to allow logins | ||||||
|   | |||||||
| @@ -1,24 +1,17 @@ | |||||||
| #!/bin/sh | #!@SHELL@ | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| #    except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| # Handle interrupts | # Handle interrupts | ||||||
| trap : SIGINT SIGQUIT | trap : SIGINT SIGQUIT | ||||||
|  |  | ||||||
| # Try and use stuff in /lib over anywhere else so we can shutdown | # Try and use stuff in /lib over anywhere else so we can shutdown | ||||||
| # local mounts correctly. | # local mounts correctly. | ||||||
| LD_LIBRARY_PATH="/lib${LD_LIBRARY_PATH:+:}${LD_LIBRARY_PATH}" ; export LD_LIBRARY_PATH | export LD_LIBRARY_PATH="/lib${LD_LIBRARY_PATH:+:}${LDLIBRARY_PATH}" | ||||||
|  |  | ||||||
| # If $TERM is not set then assume default of @TERM@ | # If $TERM is not set then assume default of @TERM@ | ||||||
| # This gives us a nice colour boot :) | # This gives us a nice colour boot :) | ||||||
| [ -z "$TERM" -o "$TERM" = "dumb" ] && TERM="@TERM@" && export TERM | [ -z "$TERM" -o "$TERM" = "dumb" ] && export TERM="@TERM@" | ||||||
|  |  | ||||||
| action=${1:-shutdown} | action=${1:-shutdown} | ||||||
| exec /sbin/openrc "${action}" | exec /sbin/rc "${action}" | ||||||
|   | |||||||
| @@ -1,47 +0,0 @@ | |||||||
| # OpenRC init process guide |  | ||||||
|  |  | ||||||
| OpenRC now includes an init process which can be used on Linux systems |  | ||||||
| in place of sysvinit. |  | ||||||
|  |  | ||||||
| ## migrating a live system to openrc-init |  | ||||||
|  |  | ||||||
| Configuring a live system to use this init process is very |  | ||||||
| straight-forward, but the steps must be completed in this order. |  | ||||||
|  |  | ||||||
| * have your boot loader add "init=/sbin/openrc-init" to the kernel command line |  | ||||||
|  |  | ||||||
| The details of how to do this will vary from distro to distro, so they are |  | ||||||
| out of scope for this document. |  | ||||||
|  |  | ||||||
| * Install gettys into the runlevels where you need them. |  | ||||||
|  |  | ||||||
| If you are using the provided /etc/init.d/agetty script,, you should |  | ||||||
| first create symlinks in /etc/init.d to it for the ports where you |  | ||||||
| want gettys to run, e.g. the following will work if you want gettys on |  | ||||||
| tty1-tty6. |  | ||||||
|  |  | ||||||
| ``` |  | ||||||
| # cd /etc/init.d |  | ||||||
| # for x in tty1 tty2 tty3 tty4 tty5 tty6; do |  | ||||||
|   ln -snf agetty agetty.$x |  | ||||||
|   done |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Once this is done, use ```rc-update``` as normal to install the agetty |  | ||||||
| services in the appropriate runlevels. |  | ||||||
|  |  | ||||||
| * Reboot your system. |  | ||||||
|  |  | ||||||
| At this point you are running under openrc-init, and you should use |  | ||||||
| openrc-shutdown to handle shutting down, powering off, rebooting etc. |  | ||||||
|  |  | ||||||
| ## optional sysvinit compatibility |  | ||||||
|  |  | ||||||
| If you build and install OpenRC with MKSYSVINIT=yes, you will build and install |  | ||||||
| wrappers that make openrc-init compatible with sysvinit -- you will have |  | ||||||
| commands like "halt" "shutdown" "reboot" and "poweroff". |  | ||||||
|  |  | ||||||
| If you want this functionality on a live system, you should first |  | ||||||
| migrate the system to openrc-init, remove sysvinit, then rebuild and |  | ||||||
| install this package with MKSYSVINIT=yes. |  | ||||||
|  |  | ||||||
							
								
								
									
										11
									
								
								init.d.misc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								init.d.misc/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | avahi-dnsconfd | ||||||
|  | avahid | ||||||
|  | dhcpcd | ||||||
|  | dbus | ||||||
|  | hald | ||||||
|  | named | ||||||
|  | ntpd | ||||||
|  | openvpn | ||||||
|  | polkitd | ||||||
|  | sshd | ||||||
|  | wpa_supplicant | ||||||
							
								
								
									
										11
									
								
								init.d.misc/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								init.d.misc/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | DIR=	${INITDIR} | ||||||
|  | SRCS=	avahi-dnsconfd.in avahid.in dhcpcd.in dbus.in \ | ||||||
|  | 	hald.in named.in ntpd.in \ | ||||||
|  | 	openvpn.in polkitd.in sshd.in wpa_supplicant.in | ||||||
|  |  | ||||||
|  | MK=	../mk | ||||||
|  |  | ||||||
|  | SED_EXTRA+= -e 's:@VARBASE@:/var:g' | ||||||
|  |  | ||||||
|  | include ${MK}/os.mk | ||||||
|  | include ${MK}/scripts.mk | ||||||
							
								
								
									
										15
									
								
								init.d.misc/avahi-dnsconfd.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								init.d.misc/avahi-dnsconfd.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/sbin/avahi-dnsconfd | ||||||
|  | command_args="$avahi_dnsconfd_args -D" | ||||||
|  | pidfile=@VARBASE@/run/avahi-dnsconfd.pid | ||||||
|  | name="Avahi DNS Configuration Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	use dns | ||||||
|  | 	need localmount dbus | ||||||
|  | 	after bootmisc | ||||||
|  | } | ||||||
							
								
								
									
										15
									
								
								init.d.misc/avahid.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								init.d.misc/avahid.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/sbin/avahi-daemon | ||||||
|  | command_args="$avahid_args -D" | ||||||
|  | pidfile=@VARBASE@/run/avahi-daemon/pid | ||||||
|  | name="Avahi Service Advertisement Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	use dns | ||||||
|  | 	need localmount dbus | ||||||
|  | 	after bootmisc | ||||||
|  | } | ||||||
							
								
								
									
										19
									
								
								init.d.misc/dbus.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								init.d.misc/dbus.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/bin/dbus-daemon | ||||||
|  | pidfile=@VARBASE@/run/dbus/pid | ||||||
|  | command_args="${dbusd_args---system}" | ||||||
|  | name="Message Bus Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	need localmount net | ||||||
|  | 	after bootmisc | ||||||
|  | } | ||||||
|  |  | ||||||
|  | start_pre() | ||||||
|  | { | ||||||
|  | 	mkdir -p $(dirname $pidfile) | ||||||
|  | } | ||||||
							
								
								
									
										27
									
								
								init.d.misc/dhcpcd.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								init.d.misc/dhcpcd.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2009 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=/sbin/dhcpcd | ||||||
|  | pidfile=/var/run/dhcpcd.pid | ||||||
|  | command_args=-q | ||||||
|  | name="DHCP Client Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	provide net | ||||||
|  | 	need localmount | ||||||
|  | 	use logger | ||||||
|  | 	after bootmisc modules | ||||||
|  | 	before dns | ||||||
|  | } | ||||||
|  |  | ||||||
|  | stop_pre() | ||||||
|  | { | ||||||
|  | 	# When shutting down, kill dhcpcd but preserve network | ||||||
|  | 	# We do this as /var/run/dhcpcd could be cleaned out when we | ||||||
|  | 	# return to multiuser. | ||||||
|  | 	if yesno $RC_GOINGDOWN; then | ||||||
|  | 		: ${stopsig:=SIGKILL} | ||||||
|  | 	fi | ||||||
|  | } | ||||||
							
								
								
									
										24
									
								
								init.d.misc/dnsmasq.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								init.d.misc/dnsmasq.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/sbin/dnsmasq | ||||||
|  | command_args=$dnsmasq_args | ||||||
|  | pidfile=@VARBASE@/run/dnsmasq.pid | ||||||
|  | required_files=/etc/dnsmasq.conf | ||||||
|  |  | ||||||
|  | extra_started_commands="reload" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	provide dns | ||||||
|  | 	need localmount net | ||||||
|  | 	after bootmisc | ||||||
|  | } | ||||||
|  |  | ||||||
|  | reload() | ||||||
|  | { | ||||||
|  | 	ebegin "Reloading $RC_SVCNAME" | ||||||
|  | 	start-stop-daemon --signal SIGHUP --pidfile "$pidfile" | ||||||
|  | 	eend $? | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								init.d.misc/hald.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								init.d.misc/hald.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/sbin/hald | ||||||
|  | pidfile=@VARBASE@/run/hald/hald.pid | ||||||
|  | command_args=$hald_args | ||||||
|  | name="Hardware Abstraction Layer Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	need dbus | ||||||
|  | } | ||||||
| @@ -1,17 +1,10 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
| 
 | 
 | ||||||
| command=/usr/sbin/named | command=/usr/sbin/named | ||||||
| command_args=$named_args | command_args=$named_args | ||||||
| pidfile=/var/run/named.pid | pidfile=@VARBASE@/run/named.pid | ||||||
| name="Domain Name server" | name="Domain Name server" | ||||||
| extra_started_commands="reload" | extra_started_commands="reload" | ||||||
| 
 | 
 | ||||||
| @@ -20,7 +13,7 @@ uid=named | |||||||
| case "$RC_UNAME" in | case "$RC_UNAME" in | ||||||
| 	FreeBSD) | 	FreeBSD) | ||||||
| 		uid=bind | 		uid=bind | ||||||
| 		pidfile=/var/run/named/pid | 		pidfile=@VARBASE@/run/named/pid | ||||||
| 		;; | 		;; | ||||||
| 	Linux) | 	Linux) | ||||||
| 		uid=bind | 		uid=bind | ||||||
| @@ -1,13 +1,6 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2009 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
| 
 | 
 | ||||||
| : ${ntpd_config:=/etc/ntp.conf} | : ${ntpd_config:=/etc/ntp.conf} | ||||||
| : ${ntpd_drift:=/var/db/ntpd.drift} | : ${ntpd_drift:=/var/db/ntpd.drift} | ||||||
| @@ -1,21 +1,14 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
| 
 | 
 | ||||||
| vpn=${RC_SVCNAME#*.} | vpn=${RC_SVCNAME#*.} | ||||||
| name="OpenVPN" | name="OpenVPN" | ||||||
| [ "$vpn" != openvpn ] && name="$name ($vpn)" | [ "$vpn" != openvpn ] && name="$name ($vpn)" | ||||||
| command=/sbin/openvpn | command=@PKG_PREFIX@/sbin/openvpn | ||||||
| 
 | 
 | ||||||
| pidfile=/var/run/"$RC_SVCNAME".pid | pidfile=@VARBASE@/run/"$RC_SVCNAME".pid | ||||||
| : ${openvpn_dir:=/etc/openvpn} | : ${openvpn_dir:=@PKG_PREFIX@/etc/openvpn} | ||||||
| : ${openvpn_config:=$openvpn_dir/$vpn.conf} | : ${openvpn_config:=$openvpn_dir/$vpn.conf} | ||||||
| command_args="$openvpn_args --daemon --config $openvpn_config" | command_args="$openvpn_args --daemon --config $openvpn_config" | ||||||
| command_args="$command_args --writepid $pidfile" | command_args="$command_args --writepid $pidfile" | ||||||
| @@ -60,7 +53,7 @@ start_pre() | |||||||
| 			eend $? | 			eend $? | ||||||
| 		fi | 		fi | ||||||
| 	else | 	else | ||||||
| 		if command -v kldload >/dev/null 2>&1; then | 		if type kldload >/dev/null 2>&1; then | ||||||
| 			# Hammer the modules home by default | 			# Hammer the modules home by default | ||||||
| 			sysctl -a | grep -q '\.tun\.' || kldload if_tun | 			sysctl -a | grep -q '\.tun\.' || kldload if_tun | ||||||
| 			sysctl -a | grep -q '\.tap\.' || kldload if_tap | 			sysctl -a | grep -q '\.tap\.' || kldload if_tap | ||||||
							
								
								
									
										13
									
								
								init.d.misc/polkitd.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								init.d.misc/polkitd.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | #!@PREFIX@/sbin/runscript | ||||||
|  | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
|  | # Released under the 2-clause BSD license. | ||||||
|  |  | ||||||
|  | command=@PKG_PREFIX@/sbin/polkitd | ||||||
|  | pidfile=@VARBASE@/run/polkitd/polkitd.pid | ||||||
|  | command_args="$polkitd_args" | ||||||
|  | name="PolicyKit Daemon" | ||||||
|  |  | ||||||
|  | depend() | ||||||
|  | { | ||||||
|  | 	need dbus | ||||||
|  | } | ||||||
| @@ -1,17 +1,10 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2008 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
| 
 | 
 | ||||||
| command=/usr/sbin/sshd | command=/usr/sbin/sshd | ||||||
| command_args=$sshd_args | command_args=$sshd_args | ||||||
| pidfile=/var/run/sshd.pid | pidfile=@VARBASE@/run/sshd.pid | ||||||
| required_files=/etc/ssh/sshd_config | required_files=/etc/ssh/sshd_config | ||||||
| 
 | 
 | ||||||
| depend() | depend() | ||||||
| @@ -1,13 +1,6 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2009 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
| 
 | 
 | ||||||
| command=/usr/sbin/wpa_supplicant | command=/usr/sbin/wpa_supplicant | ||||||
| : ${wpa_supplicant_conf:=/etc/wpa_supplicant.conf} | : ${wpa_supplicant_conf:=/etc/wpa_supplicant.conf} | ||||||
| @@ -39,11 +32,6 @@ find_wireless() | |||||||
| 			fi | 			fi | ||||||
| 		done | 		done | ||||||
| 		;; | 		;; | ||||||
| 	FreeBSD) |  | ||||||
| 		for iface in $(sysctl -b net.wlan.devices 2>/dev/null); do |  | ||||||
| 			echo "${iface##*/}" |  | ||||||
| 		done |  | ||||||
| 		;; |  | ||||||
| 	*) | 	*) | ||||||
| 		for iface in /dev/net/* $(ifconfig -l 2>/dev/null); do | 		for iface in /dev/net/* $(ifconfig -l 2>/dev/null); do | ||||||
| 			if ifconfig "${iface##*/}" 2>/dev/null | \ | 			if ifconfig "${iface##*/}" 2>/dev/null | \ | ||||||
							
								
								
									
										42
									
								
								init.d/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								init.d/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | bootmisc | ||||||
|  | fsck | ||||||
|  | hostname | ||||||
|  | local | ||||||
|  | localmount | ||||||
|  | moused | ||||||
|  | net.lo | ||||||
|  | net.lo0 | ||||||
|  | netmount | ||||||
|  | network | ||||||
|  | root | ||||||
|  | savecache | ||||||
|  | swap | ||||||
|  | sysctl | ||||||
|  | urandom | ||||||
|  | devfs | ||||||
|  | dmesg | ||||||
|  | hwclock | ||||||
|  | consolefont | ||||||
|  | keymaps | ||||||
|  | killprocs | ||||||
|  | modules | ||||||
|  | mount-ro | ||||||
|  | mtab | ||||||
|  | numlock | ||||||
|  | procfs | ||||||
|  | staticroute | ||||||
|  | sysfs | ||||||
|  | devdb | ||||||
|  | hostid | ||||||
|  | newsyslog | ||||||
|  | pf | ||||||
|  | rarpd | ||||||
|  | rc-enabled | ||||||
|  | rpcbind | ||||||
|  | savecore | ||||||
|  | swap-blk | ||||||
|  | swclock | ||||||
|  | syslogd | ||||||
|  | termencoding | ||||||
|  | ttys | ||||||
|  | wscons | ||||||
							
								
								
									
										42
									
								
								init.d/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								init.d/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | DIR=	${INITDIR} | ||||||
|  | SRCS=	bootmisc.in fsck.in hostname.in local.in localmount.in netmount.in \ | ||||||
|  | 	network.in root.in savecache.in staticroute.in swap.in swclock.in \ | ||||||
|  | 	sysctl.in urandom.in ${SRCS-${OS}} | ||||||
|  | BIN=	${OBJS} | ||||||
|  |  | ||||||
|  | INSTALLAFTER=	_installafter_net.lo | ||||||
|  | CLEANFILES+=	net.lo | ||||||
|  | TARGETS+=	net.lo | ||||||
|  |  | ||||||
|  | MK=	../mk | ||||||
|  | include ${MK}/os.mk | ||||||
|  |  | ||||||
|  | NET_LO-FreeBSD=	net.lo0 | ||||||
|  | # Generic BSD scripts | ||||||
|  | SRCS-FreeBSD=	hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \ | ||||||
|  | 		rpcbind.in savecore.in syslogd.in | ||||||
|  | # These are FreeBSD specific | ||||||
|  | SRCS-FreeBSD+=	adjkerntz.in devd.in dumpon.in ipfw.in mixer.in nscd.in \ | ||||||
|  | 		powerd.in syscons.in | ||||||
|  |  | ||||||
|  | NET_LO-Linux=	net.lo | ||||||
|  | SRCS-Linux=	devfs.in dmesg.in hwclock.in consolefont.in keymaps.in \ | ||||||
|  | 		killprocs.in modules.in mount-ro.in mtab.in numlock.in \ | ||||||
|  | 		procfs.in sysfs.in termencoding.in | ||||||
|  |  | ||||||
|  | NET_LO-NetBSD=	net.lo0 | ||||||
|  | # Generic BSD scripts | ||||||
|  | SRCS-NetBSD=	hostid.in moused.in newsyslog.in pf.in rarpd.in rc-enabled.in \ | ||||||
|  | 		rpcbind.in savecore.in syslogd.in | ||||||
|  | # These are NetBSD specific | ||||||
|  | SRCS-NetBSD+=	devdb.in swap-blk.in ttys.in wscons.in | ||||||
|  |  | ||||||
|  | %.in: %${SFX} | ||||||
|  | 	sed ${SED_REPLACE} ${SED_EXTRA} $< > $@ | ||||||
|  |  | ||||||
|  | include ${MK}/scripts.mk | ||||||
|  |  | ||||||
|  | _installafter_: realinstall | ||||||
|  |  | ||||||
|  | _installafter_net.lo: realinstall | ||||||
|  | 	${INSTALL} -m ${BINMODE} net.lo ${DESTDIR}/${INITDIR}/${NET_LO-${OS}} | ||||||
| @@ -1,13 +1,6 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2009 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| extra_commands="save" | extra_commands="save" | ||||||
|  |  | ||||||
| @@ -23,7 +16,6 @@ fi | |||||||
|  |  | ||||||
| depend() | depend() | ||||||
| { | { | ||||||
| 	after swclock |  | ||||||
| 	provide clock | 	provide clock | ||||||
| 	# BSD adjkerntz needs to be able to write to /etc | 	# BSD adjkerntz needs to be able to write to /etc | ||||||
| 	if [ "$clock" = "UTC" -a -e /etc/wall_cmos_clock ] || | 	if [ "$clock" = "UTC" -a -e /etc/wall_cmos_clock ] || | ||||||
|   | |||||||
| @@ -1,41 +0,0 @@ | |||||||
| #!@SBINDIR@/openrc-run |  | ||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| description="start agetty on a terminal line" |  | ||||||
| supervisor=supervise-daemon |  | ||||||
| port="${RC_SVCNAME#*.}" |  | ||||||
| respawn_period="${respawn_period:-60}" |  | ||||||
| term_type="${term_type:-linux}" |  | ||||||
| command=/sbin/agetty |  | ||||||
| command_args_foreground="${agetty_options} ${port} ${baud} ${term_type}" |  | ||||||
| pidfile="/run/${RC_SVCNAME}.pid" |  | ||||||
|  |  | ||||||
| depend() { |  | ||||||
| 	after local |  | ||||||
| 	keyword -prefix |  | ||||||
| 	provide getty |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start_pre() { |  | ||||||
| 	if [ "$port" = "$RC_SVCNAME" ]; then |  | ||||||
| 		eerror "${RC_SVCNAME} cannot be started directly. You must create" |  | ||||||
| 		eerror "symbolic links to it for the ports you want to start" |  | ||||||
| 		eerror "agetty on and add those to the appropriate runlevels." |  | ||||||
| 		return 1 |  | ||||||
| 	else |  | ||||||
| 		export EINFO_QUIET="${quiet:-yes}" |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| stop_pre() |  | ||||||
| { |  | ||||||
| 	export EINFO_QUIET="${quiet:-yes}" |  | ||||||
| } |  | ||||||
| @@ -1,27 +0,0 @@ | |||||||
| #!@SBINDIR@/openrc-run |  | ||||||
| # Copyright (c) 2015 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| description="Register misc binary format handlers" |  | ||||||
|  |  | ||||||
| depend() |  | ||||||
| { |  | ||||||
| 	after clock procfs |  | ||||||
| 	use modules devfs |  | ||||||
| 	keyword -docker -lxc -openvz -prefix -systemd-nspawn -vserver |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start() |  | ||||||
| { |  | ||||||
| 	ebegin "Loading custom binary format handlers" |  | ||||||
| 	"$RC_LIBEXECDIR"/sh/binfmt.sh |  | ||||||
| 	eend $? |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
| @@ -1,22 +1,20 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2009 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| depend() | depend() | ||||||
| { | { | ||||||
| 	need localmount | 	need localmount | ||||||
| 	before logger | 	before logger | ||||||
| 	after clock root sysctl | 	after clock sysctl | ||||||
| 	keyword -prefix -timeout | 	keyword -prefix -timeout | ||||||
| } | } | ||||||
|  |  | ||||||
|  | dir_writable() | ||||||
|  | { | ||||||
|  | 	mkdir "$1"/.test.$$ 2>/dev/null && rmdir "$1"/.test.$$ | ||||||
|  | } | ||||||
|  |  | ||||||
| : ${wipe_tmp:=${WIPE_TMP:-yes}} | : ${wipe_tmp:=${WIPE_TMP:-yes}} | ||||||
| : ${log_dmesg:=${LOG_DMESG:-yes}} | : ${log_dmesg:=${LOG_DMESG:-yes}} | ||||||
|  |  | ||||||
| @@ -27,16 +25,16 @@ cleanup_tmp_dir() | |||||||
| 	if ! [ -d "$dir" ]; then | 	if ! [ -d "$dir" ]; then | ||||||
| 		mkdir -p "$dir" || return $? | 		mkdir -p "$dir" || return $? | ||||||
| 	fi | 	fi | ||||||
| 	checkpath -W "$dir" || return 1 | 	dir_writable "$dir" || return 1 | ||||||
| 	chmod a+rwt "$dir" 2> /dev/null | 	chmod a+rwt "$dir" 2> /dev/null | ||||||
| 	cd "$dir" || return 1 | 	cd "$dir" || return 1 | ||||||
| 	if yesno $wipe_tmp; then | 	if yesno $wipe_tmp; then | ||||||
| 		ebegin "Wiping $dir directory" | 		ebegin "Wiping $dir directory" | ||||||
|  |  | ||||||
| 		# Faster than raw find | 		# Faster than raw find | ||||||
| 		if ! rm -rf -- [!ajlq\.]* 2>/dev/null ; then | 		if ! rm -rf -- [^ajlq\.]* 2>/dev/null ; then | ||||||
| 			# Blah, too many files | 			# Blah, too many files | ||||||
| 			find . -maxdepth 1 -name '[!ajlq\.]*' -exec rm -rf -- {} + | 			find . -maxdepth 1 -name '[^ajlq\.]*' -exec rm -rf -- {} + | ||||||
| 		fi | 		fi | ||||||
|  |  | ||||||
| 		# pam_mktemp creates a .private directory within which | 		# pam_mktemp creates a .private directory within which | ||||||
| @@ -66,35 +64,6 @@ cleanup_tmp_dir() | |||||||
| 	fi | 	fi | ||||||
| } | } | ||||||
|  |  | ||||||
| cleanup_var_run_dir() |  | ||||||
| { |  | ||||||
| 	ebegin "Cleaning /var/run" |  | ||||||
| 	for x in $(find /var/run ! -type d ! -name utmp \ |  | ||||||
| 		! -name random-seed ! -name dev.db \ |  | ||||||
| 		! -name ld-elf.so.hints ! -name ld-elf32.so.hints \ |  | ||||||
| 		! -name ld.so.hints); |  | ||||||
| 	do |  | ||||||
| 		# Clean stale sockets |  | ||||||
| 		if [ -S "$x" ]; then |  | ||||||
| 			if command -v fuser >/dev/null 2>&1; then |  | ||||||
| 				fuser "$x" >/dev/null 2>&1 || rm -- "$x" |  | ||||||
| 			else |  | ||||||
| 				rm -- "$x" |  | ||||||
| 			fi |  | ||||||
| 		fi |  | ||||||
| 		[ ! -f "$x" ] && continue |  | ||||||
| 		# Do not remove pidfiles of already running daemons |  | ||||||
| 		case "$x" in |  | ||||||
| 			*.pid) |  | ||||||
| 				start-stop-daemon --test --quiet \ |  | ||||||
| 				--stop --pidfile "$x" && continue |  | ||||||
| 			;; |  | ||||||
| 		esac |  | ||||||
| 		rm -f -- "$x" |  | ||||||
| 	done |  | ||||||
| 	eend 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mkutmp() | mkutmp() | ||||||
| { | { | ||||||
| 	: >"$1" | 	: >"$1" | ||||||
| @@ -113,10 +82,8 @@ migrate_to_run() | |||||||
|  		rm $src |  		rm $src | ||||||
|  	elif [ ! -L $src -a -d $src ]; then |  	elif [ ! -L $src -a -d $src ]; then | ||||||
|  		ebegin "Migrating $src to $dst" |  		ebegin "Migrating $src to $dst" | ||||||
|  		if ! rmdir $src 2>/dev/null; then |  		cp -a $src/* $dst/ | ||||||
|  			cp -a $src/* $dst/ |  		rm -rf $src | ||||||
|  			rm -rf $src |  | ||||||
|  		fi |  | ||||||
|  		eend $? |  		eend $? | ||||||
|  	fi |  	fi | ||||||
|  	# If $src doesn't exist at all, just run this |  	# If $src doesn't exist at all, just run this | ||||||
| @@ -125,43 +92,10 @@ migrate_to_run() | |||||||
|  	fi |  	fi | ||||||
| } | } | ||||||
|  |  | ||||||
| clean_run() |  | ||||||
| { |  | ||||||
| 	[ "$RC_SYS" = VSERVER -o "$RC_SYS" = LXC ] && return 0 |  | ||||||
| 	local dir |  | ||||||
| 	# If / is still read-only due to a problem, this will fail! |  | ||||||
| 	if ! checkpath -W /; then |  | ||||||
| 		ewarn "/ is not writable; unable to clean up underlying /run" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| 	if ! checkpath -W /tmp; then |  | ||||||
| 		ewarn "/tmp is not writable; unable to clean up underlying /run" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| 	# Now we know that we can modify /tmp and / |  | ||||||
| 	# if mktemp -d fails, it returns an EMPTY string |  | ||||||
| 	# STDERR: mktemp: failed to create directory via template ‘/tmp/tmp.XXXXXXXXXX’: Read-only file system |  | ||||||
| 	# STDOUT: '' |  | ||||||
| 	rc=0 |  | ||||||
| 	dir=$(mktemp -d) |  | ||||||
| 	if [ -n "$dir" -a -d $dir -a -w $dir ]; then |  | ||||||
| 		mount --bind / $dir && rm -rf $dir/run/* || rc=1 |  | ||||||
| 		umount $dir && rmdir $dir |  | ||||||
| 	else |  | ||||||
| 		rc=1 |  | ||||||
| 	fi |  | ||||||
| 	if [ $rc -ne 0 ]; then |  | ||||||
| 		ewarn "Could not clean up underlying /run on /" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start() | start() | ||||||
| { | { | ||||||
| 	# Remove any added console dirs | 	# Remove any added console dirs | ||||||
| 	if checkpath -W "$RC_LIBEXECDIR"; then | 	rm -rf "$RC_LIBEXECDIR"/console/* | ||||||
| 		rm -rf "$RC_LIBEXECDIR"/console/* |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	local logw=false runw=false extra= | 	local logw=false runw=false extra= | ||||||
| 	# Ensure that our basic dirs exist | 	# Ensure that our basic dirs exist | ||||||
| @@ -183,13 +117,12 @@ start() | |||||||
| 		fi | 		fi | ||||||
| 	done | 	done | ||||||
|  |  | ||||||
| 	if [ "$RC_UNAME" = Linux -a -d /run ]; then | 	if [ "$RC_UNAME" = Linux -a -d /run ] && false; then | ||||||
| 		migrate_to_run	/var/lock /run/lock | 		migrate_to_run	/var/lock /run/lock | ||||||
| 		migrate_to_run	/var/run /run | 		migrate_to_run	/var/run /run | ||||||
| 		clean_run |  | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	if checkpath -W /var/run; then | 	if dir_writable /var/run; then | ||||||
| 		ebegin "Creating user login records" | 		ebegin "Creating user login records" | ||||||
| 		local xtra= | 		local xtra= | ||||||
| 		[ "$RC_UNAME" = NetBSD ] && xtra=x | 		[ "$RC_UNAME" = NetBSD ] && xtra=x | ||||||
| @@ -199,16 +132,39 @@ start() | |||||||
| 		[ -e /var/log/wtmp ] || mkutmp /var/log/wtmp | 		[ -e /var/log/wtmp ] || mkutmp /var/log/wtmp | ||||||
| 		eend 0 | 		eend 0 | ||||||
|  |  | ||||||
| 		mountinfo -q -f tmpfs /var/run || cleanup_var_run_dir | 		ebegin "Cleaning /var/run" | ||||||
|  | 		for x in $(find /var/run ! -type d ! -name utmp \ | ||||||
|  | 			! -name random-seed ! -name dev.db \ | ||||||
|  | 			! -name ld-elf.so.hints ! -name ld.so.hints); | ||||||
|  | 		do | ||||||
|  | 			# Clean stale sockets | ||||||
|  | 			if [ -S "$x" ]; then | ||||||
|  | 				if type fuser >/dev/null 2>&1; then | ||||||
|  | 					fuser "$x" >/dev/null 2>&1 || rm -- "$x" | ||||||
|  | 				else | ||||||
|  | 					rm -- "$x" | ||||||
|  | 				fi | ||||||
|  | 			fi | ||||||
|  | 			[ ! -f "$x" ] && continue | ||||||
|  | 			# Do not remove pidfiles of already running daemons | ||||||
|  | 			case "$x" in | ||||||
|  | 				*.pid) | ||||||
|  | 					start-stop-daemon --test --quiet \ | ||||||
|  | 					--stop --pidfile "$x" && continue | ||||||
|  | 				;; | ||||||
|  | 			esac | ||||||
|  | 			rm -f -- "$x" | ||||||
|  | 		done | ||||||
|  | 		eend 0 | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	# Clean up /tmp directories | 	# Clean up /tmp directories | ||||||
| 	local tmp= | 	local tmp= | ||||||
| 	for tmp in ${clean_tmp_dirs:-${wipe_tmp_dirs-/tmp}}; do | 	for tmp in ${clean_tmp_dirs:-${wipe_tmp_dirs-/tmp}}; do | ||||||
| 		mountinfo -q -f tmpfs "$tmp" || cleanup_tmp_dir "$tmp" | 		cleanup_tmp_dir "$tmp" | ||||||
| 	done | 	done | ||||||
|  |  | ||||||
| 	if checkpath -W /tmp; then | 	if dir_writable /tmp; then | ||||||
| 		# Make sure our X11 stuff have the correct permissions | 		# Make sure our X11 stuff have the correct permissions | ||||||
| 		# Omit the chown as bootmisc is run before network is up | 		# Omit the chown as bootmisc is run before network is up | ||||||
| 		# and users may be using lame LDAP auth #139411 | 		# and users may be using lame LDAP auth #139411 | ||||||
| @@ -221,21 +177,16 @@ start() | |||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	if yesno $log_dmesg; then | 	if yesno $log_dmesg; then | ||||||
| 		if $logw || checkpath -W /var/log; then | 		if $logw || dir_writable /var/log; then | ||||||
| 			# Create an 'after-boot' dmesg log | 			# Create an 'after-boot' dmesg log | ||||||
| 			case "$RC_SYS" in | 			if [ "$RC_SYS" != VSERVER -a "$RC_SYS" != OPENVZ ]; then | ||||||
| 				VSERVER|OPENVZ|LXC|SYSTEMD-NSPAWN) ;; | 				dmesg > /var/log/dmesg | ||||||
| 				*) | 				chmod 640 /var/log/dmesg | ||||||
| 					if yesno ${previous_dmesg:-no} && [ -e /var/log/dmesg ]; then | 			fi | ||||||
| 						mv /var/log/dmesg /var/log/dmesg.old |  | ||||||
| 					fi |  | ||||||
| 					dmesg > /var/log/dmesg |  | ||||||
| 					chmod 640 /var/log/dmesg |  | ||||||
| 					;; |  | ||||||
| 			esac |  | ||||||
| 		fi | 		fi | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
|  | 	[ -w /etc/nologin ] && rm -f /etc/nologin | ||||||
| 	return 0 | 	return 0 | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -243,13 +194,7 @@ stop() | |||||||
| { | { | ||||||
| 	# Write a halt record if we're shutting down | 	# Write a halt record if we're shutting down | ||||||
| 	if [ "$RC_RUNLEVEL" = shutdown ]; then | 	if [ "$RC_RUNLEVEL" = shutdown ]; then | ||||||
| 		if [ "$RC_UNAME" = Linux ]; then | 		[ "$RC_UNAME" = Linux ] && halt -w | ||||||
| 			if [ -x /sbin/halt ]; then |  | ||||||
| 				halt -w |  | ||||||
| 			else |  | ||||||
| 				openrc-shutdown -w |  | ||||||
| 			fi |  | ||||||
| 		fi |  | ||||||
| 		if [ "$RC_SYS" = OPENVZ ]; then | 		if [ "$RC_SYS" = OPENVZ ]; then | ||||||
| 			yesno $RC_REBOOT && printf "" >/reboot | 			yesno $RC_REBOOT && printf "" >/reboot | ||||||
| 		fi | 		fi | ||||||
| @@ -257,5 +202,3 @@ stop() | |||||||
|  |  | ||||||
| 	return 0 | 	return 0 | ||||||
| } | } | ||||||
|  |  | ||||||
| # vim: ft=sh |  | ||||||
|   | |||||||
| @@ -1,157 +0,0 @@ | |||||||
| #!@SBINDIR@/openrc-run |  | ||||||
| # Copyright (c) 2017 The OpenRC Authors. |  | ||||||
| # See the Authors file at the top-level directory of this distribution and |  | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| description="Mount the control groups." |  | ||||||
|  |  | ||||||
| cgroup_opts=nodev,noexec,nosuid |  | ||||||
|  |  | ||||||
| depend() |  | ||||||
| { |  | ||||||
| 	keyword -docker -prefix -systemd-nspawn -vserver |  | ||||||
| 	after sysfs |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroup1_base() |  | ||||||
| { |  | ||||||
| 	grep -qw cgroup /proc/filesystems || return 0 |  | ||||||
| 	if ! mountinfo -q /sys/fs/cgroup; then |  | ||||||
| 		ebegin "Mounting cgroup filesystem" |  | ||||||
| 		local opts="${cgroup_opts},mode=755,size=${rc_cgroupsize:-10m}" |  | ||||||
| 		mount -n -t tmpfs -o "${opts}" cgroup_root /sys/fs/cgroup |  | ||||||
| 		eend $? |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	if ! mountinfo -q /sys/fs/cgroup/openrc; then |  | ||||||
| 		local agent="${RC_LIBEXECDIR}/sh/cgroup-release-agent.sh" |  | ||||||
| 		mkdir /sys/fs/cgroup/openrc |  | ||||||
| 		mount -n -t cgroup \ |  | ||||||
| 			-o none,${cgroup_opts},name=openrc,release_agent="$agent" \ |  | ||||||
| 			openrc /sys/fs/cgroup/openrc |  | ||||||
| 		printf 1 > /sys/fs/cgroup/openrc/notify_on_release |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroup1_controllers() |  | ||||||
| { |  | ||||||
| 	yesno "${rc_controller_cgroups:-YES}" && [ -e /proc/cgroups ]  && |  | ||||||
| 	grep -qw cgroup /proc/filesystems || return 0 |  | ||||||
| 	while read -r name _ _ enabled _; do |  | ||||||
| 		case "${enabled}" in |  | ||||||
| 			1)	mountinfo -q "/sys/fs/cgroup/${name}" && continue |  | ||||||
| 				local x |  | ||||||
| 				for x in $rc_cgroup_controllers; do |  | ||||||
| 				[ "${name}" = "blkio" ] && [ "${x}" = "io" ] && |  | ||||||
| 					continue 2 |  | ||||||
| 				[ "${name}" = "${x}" ] && |  | ||||||
| 				continue 2 |  | ||||||
| 				done |  | ||||||
| 				mkdir "/sys/fs/cgroup/${name}" |  | ||||||
| 				mount -n -t cgroup -o "${cgroup_opts},${name}" \ |  | ||||||
| 					"${name}" "/sys/fs/cgroup/${name}" |  | ||||||
| 				yesno "${rc_cgroup_memory_use_hierarchy:-no}" && |  | ||||||
| 					[ "${name}" = memory ] && |  | ||||||
| 					echo 1 > /sys/fs/cgroup/memory/memory.use_hierarchy |  | ||||||
| 				;; |  | ||||||
| 		esac |  | ||||||
| 	done < /proc/cgroups |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroup2_base() |  | ||||||
| { |  | ||||||
| 	grep -qw cgroup2 /proc/filesystems || return 0 |  | ||||||
| 	local base |  | ||||||
| 	base="$(cgroup2_find_path)" |  | ||||||
| 	mkdir -p "${base}" |  | ||||||
| 	mount -t cgroup2 none -o "${cgroup_opts},nsdelegate" "${base}" 2> /dev/null || |  | ||||||
| 		mount -t cgroup2 none -o "${cgroup_opts}" "${base}" |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroup2_controllers() |  | ||||||
| { |  | ||||||
| 	grep -qw cgroup2 /proc/filesystems || return 0 |  | ||||||
| 	local active cgroup_path x y |  | ||||||
| 	cgroup_path="$(cgroup2_find_path)" |  | ||||||
| 	[ -z "${cgroup_path}" ] && return 0 |  | ||||||
| 	[ ! -e "${cgroup_path}/cgroup.controllers" ] && return 0 |  | ||||||
| 	[ ! -e "${cgroup_path}/cgroup.subtree_control" ]&& return 0 |  | ||||||
| 	read -r active < "${cgroup_path}/cgroup.controllers" |  | ||||||
| 	for x in ${active}; do |  | ||||||
| 	case "$rc_cgroup_mode" in |  | ||||||
| 		unified) |  | ||||||
| 			echo "+${x}"  > "${cgroup_path}/cgroup.subtree_control" |  | ||||||
| 			;; |  | ||||||
| 		hybrid) |  | ||||||
| 			for y in ${rc_cgroup_controllers}; do |  | ||||||
| 				if [ "$x" = "$y" ]; then |  | ||||||
| 					echo "+${x}"  > "${cgroup_path}/cgroup.subtree_control" |  | ||||||
| 				fi |  | ||||||
| 			done |  | ||||||
| 			;; |  | ||||||
| 		esac |  | ||||||
| 	done |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroups_hybrid() |  | ||||||
| { |  | ||||||
| 	cgroup1_base |  | ||||||
| 	cgroup2_base |  | ||||||
| 	cgroup2_controllers |  | ||||||
| 	cgroup1_controllers |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroups_legacy() |  | ||||||
| { |  | ||||||
| 	cgroup1_base |  | ||||||
| 	cgroup1_controllers |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cgroups_unified() |  | ||||||
| { |  | ||||||
| 	cgroup2_base |  | ||||||
| 	cgroup2_controllers |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mount_cgroups() |  | ||||||
| { |  | ||||||
| 	case "${rc_cgroup_mode:-hybrid}" in |  | ||||||
| 	hybrid) cgroups_hybrid ;; |  | ||||||
| 	legacy) cgroups_legacy ;; |  | ||||||
| 	unified) cgroups_unified ;; |  | ||||||
| 	esac |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| restorecon_cgroups() |  | ||||||
| { |  | ||||||
| 	if [ -x /sbin/restorecon ]; then |  | ||||||
| 		ebegin "Restoring SELinux contexts in /sys/fs/cgroup" |  | ||||||
| 		restorecon -rF /sys/fs/cgroup >/dev/null 2>&1 |  | ||||||
| 		eend $? |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start() |  | ||||||
| { |  | ||||||
| 	# set up kernel support for cgroups |  | ||||||
| 	if [ -d /sys/fs/cgroup ]; then |  | ||||||
| 		mount_cgroups |  | ||||||
| 		restorecon_cgroups |  | ||||||
| 	fi |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
| @@ -1,21 +1,14 @@ | |||||||
| #!@SBINDIR@/openrc-run | #!@PREFIX@/sbin/runscript | ||||||
| # Copyright (c) 2007-2015 The OpenRC Authors. | # Copyright (c) 2007-2009 Roy Marples <roy@marples.name> | ||||||
| # See the Authors file at the top-level directory of this distribution and | # Released under the 2-clause BSD license. | ||||||
| # https://github.com/OpenRC/openrc/blob/HEAD/AUTHORS |  | ||||||
| # |  | ||||||
| # This file is part of OpenRC. It is subject to the license terms in |  | ||||||
| # the LICENSE file found in the top-level directory of this |  | ||||||
| # distribution and at https://github.com/OpenRC/openrc/blob/HEAD/LICENSE |  | ||||||
| # This file may not be copied, modified, propagated, or distributed |  | ||||||
| # except according to the terms contained in the LICENSE file. |  | ||||||
|  |  | ||||||
| description="Sets a font for the consoles." | description="Sets a font for the consoles." | ||||||
|  |  | ||||||
| depend() | depend() | ||||||
| { | { | ||||||
| 	need termencoding | 	need localmount termencoding | ||||||
| 	after hotplug bootmisc modules | 	after hotplug bootmisc | ||||||
| 	keyword -docker -lxc -openvz -prefix -systemd-nspawn -uml -vserver -xenu | 	keyword -openvz -prefix -uml -vserver -xenu -lxc | ||||||
| } | } | ||||||
|  |  | ||||||
| start() | start() | ||||||
| @@ -60,10 +53,14 @@ start() | |||||||
| 	done | 	done | ||||||
| 	eend $retval | 	eend $retval | ||||||
|  |  | ||||||
| 	# Store the font so we can use it ASAP on boot | 	# Store the last font so we can use it ASAP on boot | ||||||
| 	if [ $retval -eq 0 ] && checkpath -W "$RC_LIBEXECDIR"; then | 	if [ $retval -eq 0 -a -w "$RC_LIBEXECDIR" ]; then | ||||||
| 		mkdir -p "$RC_LIBEXECDIR"/console | 		mkdir -p "$RC_LIBEXECDIR"/console | ||||||
| 		setfont -O "$RC_LIBEXECDIR"/console/font | 		for font in /usr/share/consolefonts/"$consolefont".*; do | ||||||
|  | 			: | ||||||
|  | 		done | ||||||
|  | 		cp "$font" "$RC_LIBEXECDIR"/console | ||||||
|  | 		echo "${font##*/}" >"$RC_LIBEXECDIR"/console/font | ||||||
| 	fi | 	fi | ||||||
|  |  | ||||||
| 	return $retval | 	return $retval | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user