Merge branch 'joeyconfig'

This commit is contained in:
Joey Hess 2015-02-28 14:19:30 -04:00
commit 15b2c167b5
4 changed files with 66 additions and 12 deletions

View File

@ -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

43
doc/components.mdwn Normal file
View File

@ -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.

View 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]]

View File

@ -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"