Merge branch 'joeyconfig'
This commit is contained in:
commit
15b2c167b5
|
@ -6,8 +6,8 @@ are satisfied.
|
||||||
Propellor is configured via a git repository, which typically lives
|
Propellor is configured via a git repository, which typically lives
|
||||||
in `~/.propellor/` on your development machine. Propellor clones the
|
in `~/.propellor/` on your development machine. Propellor clones the
|
||||||
repository to each host it manages, in a
|
repository to each host it manages, in a
|
||||||
[secure](http://propellor.branchable.com/security/) way. The git repository
|
[secure](http://propellor.branchable.com/security/) way. See [[components]]
|
||||||
contains the full source code to Propellor, along with its config file.
|
for details.
|
||||||
|
|
||||||
Properties are defined using Haskell. Edit `~/.propellor/config.hs`
|
Properties are defined using Haskell. Edit `~/.propellor/config.hs`
|
||||||
to get started. There is fairly complete
|
to get started. There is fairly complete
|
||||||
|
|
|
@ -0,0 +1,43 @@
|
||||||
|
Propellor is a single system, but it's made up of some logically separate
|
||||||
|
components.
|
||||||
|
|
||||||
|
* Propellor is a Haskell library. The library can be installed
|
||||||
|
[from hackage](http://hackage.haskell.org/package/propellor)
|
||||||
|
in the usual ways. It complies with the
|
||||||
|
[[Haskell Package Version Policy|interface_stability]].
|
||||||
|
* `~/.propellor/` is a git repository, which contains at least your
|
||||||
|
`config.hs` file and a cabal file. This gets deployed to each machine
|
||||||
|
you manage with propellor, where it's installed as `/usr/local/propellor/`
|
||||||
|
* There can also be a propellor command in your PATH. If you `apt-get
|
||||||
|
install propellor`, you'll get one installed, or `cabal install propellor`
|
||||||
|
will put the command in `~/.cabal/bin/propellor`. This propellor command
|
||||||
|
is just a wrapper; it builds and runs what you have set up in `~/.propellor/`
|
||||||
|
|
||||||
|
Typically, the `~/.propellor/` git repository is set up by running the
|
||||||
|
propellor command, or by [[cloning propellor|install]]. That makes
|
||||||
|
the repository contain the full source code to propellor, including
|
||||||
|
the Haskell library.
|
||||||
|
|
||||||
|
So if you want to, you can edit any part of Propellor's source code.
|
||||||
|
Don't like how a property works, or need to make it more general? Just edit
|
||||||
|
then copy in `~/.propellor/src/Propellor/` and it will be used. See
|
||||||
|
[[contributing]] if you want to send your improvements back.
|
||||||
|
|
||||||
|
All that really needs to be in `~/.propellor/` though, is a `config.hs`
|
||||||
|
file, and a cabal file. If you want to set up the repository manually,
|
||||||
|
and don't want it to contain propellor's source code, here's a stub cabal
|
||||||
|
file to get you started:
|
||||||
|
|
||||||
|
<pre>
|
||||||
|
Name: foo
|
||||||
|
Cabal-Version: >= 1.6
|
||||||
|
Build-Type: Simple
|
||||||
|
Version: 0
|
||||||
|
|
||||||
|
Executable propellor-config
|
||||||
|
Main-Is: config.hs
|
||||||
|
GHC-Options: -Wall -threaded -O0
|
||||||
|
Build-Depends: propellor, base >= 3
|
||||||
|
</pre>
|
||||||
|
|
||||||
|
See [[haskell_newbie]] for an example config.hs file.
|
|
@ -6,6 +6,7 @@ Other documentation:
|
||||||
* [[man page|usage]]
|
* [[man page|usage]]
|
||||||
* [[Haskell Newbie]]
|
* [[Haskell Newbie]]
|
||||||
* [[Centralized Git Repository]]
|
* [[Centralized Git Repository]]
|
||||||
|
* [[Components]]
|
||||||
* [[Contributing]]
|
* [[Contributing]]
|
||||||
* [[Interface Stability]]
|
* [[Interface Stability]]
|
||||||
* [[Coding Stye]]
|
* [[Coding Stye]]
|
||||||
|
|
|
@ -13,7 +13,7 @@ import Data.List
|
||||||
type ShellCommand = String
|
type ShellCommand = String
|
||||||
|
|
||||||
-- Shell command line to build propellor, used when bootstrapping on a new
|
-- Shell command line to build propellor, used when bootstrapping on a new
|
||||||
-- host. Should be run inside the propellor source tree, and will install
|
-- host. Should be run inside the propellor config dir, and will install
|
||||||
-- all necessary build dependencies.
|
-- all necessary build dependencies.
|
||||||
bootstrapPropellorCommand :: ShellCommand
|
bootstrapPropellorCommand :: ShellCommand
|
||||||
bootstrapPropellorCommand = "if ! test -x ./propellor; then " ++ go ++ "; fi"
|
bootstrapPropellorCommand = "if ! test -x ./propellor; then " ++ go ++ "; fi"
|
||||||
|
@ -30,23 +30,34 @@ buildCommand = intercalate " && "
|
||||||
, "ln -sf dist/build/propellor-config/propellor-config propellor"
|
, "ln -sf dist/build/propellor-config/propellor-config propellor"
|
||||||
]
|
]
|
||||||
|
|
||||||
|
-- Install build dependencies of propellor.
|
||||||
|
--
|
||||||
|
-- First, try to install ghc, cabal, gnupg, and all haskell libraries that
|
||||||
|
-- propellor uses from OS packages.
|
||||||
|
--
|
||||||
|
-- Some packages may not be available in some versions of Debian
|
||||||
|
-- (eg, Debian wheezy lacks async), or propellor may need a newer version.
|
||||||
|
-- So, as a second step, cabal is used to install all dependencies.
|
||||||
|
--
|
||||||
|
-- Note: May succeed and leave some deps not installed.
|
||||||
depsCommand :: ShellCommand
|
depsCommand :: ShellCommand
|
||||||
depsCommand =
|
depsCommand = "( " ++ intercalate " ; " (concat [osinstall, cabalinstall]) ++ " ) || true"
|
||||||
"(" ++ aptinstall debdeps ++ " || (apt-get update && " ++ aptinstall debdeps ++ ")) && "
|
|
||||||
++ "(" ++ aptinstall ["libghc-async-dev"] ++ " || (" ++ cabalinstall ["async"] ++ ")) || "
|
|
||||||
++ "(" ++ cabalinstall ["--only-dependencies"] ++ ")"
|
|
||||||
where
|
where
|
||||||
aptinstall ps = "apt-get --no-upgrade --no-install-recommends -y install " ++ unwords ps
|
osinstall = "apt-get update" : map aptinstall debdeps
|
||||||
|
|
||||||
cabalinstall ps = "cabal update; cabal install " ++ unwords ps
|
cabalinstall =
|
||||||
|
[ "cabal update"
|
||||||
|
, "cabal install --only-dependencies"
|
||||||
|
]
|
||||||
|
|
||||||
|
aptinstall p = "apt-get --no-upgrade --no-install-recommends -y install " ++ p
|
||||||
|
|
||||||
-- This is the same build deps listed in debian/control.
|
-- This is the same build deps listed in debian/control.
|
||||||
debdeps =
|
debdeps =
|
||||||
[ "gnupg"
|
[ "gnupg"
|
||||||
, "ghc"
|
, "ghc"
|
||||||
, "cabal-install"
|
, "cabal-install"
|
||||||
-- async is not available in debian stable
|
, "libghc-async-dev"
|
||||||
-- , "libghc-async-dev"
|
|
||||||
, "libghc-missingh-dev"
|
, "libghc-missingh-dev"
|
||||||
, "libghc-hslogger-dev"
|
, "libghc-hslogger-dev"
|
||||||
, "libghc-unix-compat-dev"
|
, "libghc-unix-compat-dev"
|
||||||
|
@ -58,7 +69,6 @@ depsCommand =
|
||||||
, "libghc-monadcatchio-transformers-dev"
|
, "libghc-monadcatchio-transformers-dev"
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
installGitCommand :: ShellCommand
|
installGitCommand :: ShellCommand
|
||||||
installGitCommand = "if ! git --version >/dev/null; then apt-get update && apt-get --no-install-recommends --no-upgrade -y install git; fi"
|
installGitCommand = "if ! git --version >/dev/null; then apt-get update && apt-get --no-install-recommends --no-upgrade -y install git; fi"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue