mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-01 23:22:37 +00:00
cloud-init: 0.7.6 -> 0.7.9
This commit is contained in:
parent
a9584c9510
commit
2e4d0ff2e0
113
pkgs/tools/virtualization/cloud-init/add-nixos-support.patch
Normal file
113
pkgs/tools/virtualization/cloud-init/add-nixos-support.patch
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
diff -ruN cloud-init-0.7.6.orig/cloudinit/distros/__init__.py cloud-init-0.7.6/cloudinit/distros/__init__.py
|
||||||
|
--- cloud-init-0.7.6.orig/cloudinit/distros/__init__.py 2014-10-10 15:26:25.000000000 +0000
|
||||||
|
+++ cloud-init-0.7.6/cloudinit/distros/__init__.py 2016-06-08 07:51:45.230357099 +0000
|
||||||
|
@@ -43,6 +43,7 @@
|
||||||
|
'freebsd': ['freebsd'],
|
||||||
|
'suse': ['sles'],
|
||||||
|
'arch': ['arch'],
|
||||||
|
+ 'nixos': ['nixos'],
|
||||||
|
}
|
||||||
|
|
||||||
|
LOG = logging.getLogger(__name__)
|
||||||
|
diff -ruN cloud-init-0.7.6.orig/cloudinit/distros/nixos.py cloud-init-0.7.6/cloudinit/distros/nixos.py
|
||||||
|
--- cloud-init-0.7.6.orig/cloudinit/distros/nixos.py 1970-01-01 00:00:00.000000000 +0000
|
||||||
|
+++ cloud-init-0.7.6/cloudinit/distros/nixos.py 2016-06-08 07:50:58.602616595 +0000
|
||||||
|
@@ -0,0 +1,98 @@
|
||||||
|
+# vi: ts=4 expandtab
|
||||||
|
+#
|
||||||
|
+# Copyright (C) 2012 Canonical Ltd.
|
||||||
|
+# Copyright (C) 2012 Hewlett-Packard Development Company, L.P.
|
||||||
|
+# Copyright (C) 2012 Yahoo! Inc.
|
||||||
|
+#
|
||||||
|
+# Author: Scott Moser <scott.moser@canonical.com>
|
||||||
|
+# Author: Juerg Haefliger <juerg.haefliger@hp.com>
|
||||||
|
+# Author: Joshua Harlow <harlowja@yahoo-inc.com>
|
||||||
|
+#
|
||||||
|
+# This program is free software: you can redistribute it and/or modify
|
||||||
|
+# it under the terms of the GNU General Public License version 3, as
|
||||||
|
+# published by the Free Software Foundation.
|
||||||
|
+#
|
||||||
|
+# This program is distributed in the hope that it will be useful,
|
||||||
|
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+# GNU General Public License for more details.
|
||||||
|
+#
|
||||||
|
+# You should have received a copy of the GNU General Public License
|
||||||
|
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+
|
||||||
|
+from cloudinit import distros
|
||||||
|
+from cloudinit import helpers
|
||||||
|
+from cloudinit import log as logging
|
||||||
|
+from cloudinit import util
|
||||||
|
+
|
||||||
|
+from cloudinit.distros.parsers.hostname import HostnameConf
|
||||||
|
+
|
||||||
|
+LOG = logging.getLogger(__name__)
|
||||||
|
+
|
||||||
|
+class Distro(distros.Distro):
|
||||||
|
+
|
||||||
|
+ def __init__(self, name, cfg, paths):
|
||||||
|
+ distros.Distro.__init__(self, name, cfg, paths)
|
||||||
|
+ # This will be used to restrict certain
|
||||||
|
+ # calls from repeatly happening (when they
|
||||||
|
+ # should only happen say once per instance...)
|
||||||
|
+ self._runner = helpers.Runners(paths)
|
||||||
|
+ self.osfamily = 'nixos'
|
||||||
|
+
|
||||||
|
+ def _select_hostname(self, hostname, fqdn):
|
||||||
|
+ # Prefer the short hostname over the long
|
||||||
|
+ # fully qualified domain name
|
||||||
|
+ if not hostname:
|
||||||
|
+ return fqdn
|
||||||
|
+ return hostname
|
||||||
|
+
|
||||||
|
+ def _write_hostname(self, your_hostname, out_fn):
|
||||||
|
+ conf = None
|
||||||
|
+ try:
|
||||||
|
+ # Try to update the previous one
|
||||||
|
+ # so lets see if we can read it first.
|
||||||
|
+ conf = self._read_hostname_conf(out_fn)
|
||||||
|
+ except IOError:
|
||||||
|
+ pass
|
||||||
|
+ if not conf:
|
||||||
|
+ conf = HostnameConf('')
|
||||||
|
+ conf.set_hostname(your_hostname)
|
||||||
|
+ util.write_file(out_fn, str(conf), 0644)
|
||||||
|
+
|
||||||
|
+ def _read_system_hostname(self):
|
||||||
|
+ sys_hostname = self._read_hostname(self.hostname_conf_fn)
|
||||||
|
+ return (self.hostname_conf_fn, sys_hostname)
|
||||||
|
+
|
||||||
|
+ def _read_hostname_conf(self, filename):
|
||||||
|
+ conf = HostnameConf(util.load_file(filename))
|
||||||
|
+ conf.parse()
|
||||||
|
+ return conf
|
||||||
|
+
|
||||||
|
+ def _read_hostname(self, filename, default=None):
|
||||||
|
+ hostname = None
|
||||||
|
+ try:
|
||||||
|
+ conf = self._read_hostname_conf(filename)
|
||||||
|
+ hostname = conf.hostname
|
||||||
|
+ except IOError:
|
||||||
|
+ pass
|
||||||
|
+ if not hostname:
|
||||||
|
+ return default
|
||||||
|
+ return hostname
|
||||||
|
+
|
||||||
|
+ def _write_network(self, settings):
|
||||||
|
+ raise NotImplementedError()
|
||||||
|
+
|
||||||
|
+ def apply_locale(self, locale, out_fn=None):
|
||||||
|
+ raise NotImplementedError()
|
||||||
|
+
|
||||||
|
+ def install_packages(self, pkglist):
|
||||||
|
+ raise NotImplementedError()
|
||||||
|
+
|
||||||
|
+ def package_command(self, command, args=None, pkgs=None):
|
||||||
|
+ raise NotImplementedError()
|
||||||
|
+
|
||||||
|
+ def set_timezone(self, tz):
|
||||||
|
+ raise NotImplementedError()
|
||||||
|
+
|
||||||
|
+ def update_package_sources(self):
|
||||||
|
+ raise NotImplementedError()
|
@ -1,6 +1,6 @@
|
|||||||
{ lib, pythonPackages, fetchurl }:
|
{ lib, pythonPackages, fetchurl, kmod, systemd }:
|
||||||
|
|
||||||
let version = "0.7.6";
|
let version = "0.7.9";
|
||||||
|
|
||||||
in pythonPackages.buildPythonApplication rec {
|
in pythonPackages.buildPythonApplication rec {
|
||||||
name = "cloud-init-${version}";
|
name = "cloud-init-${version}";
|
||||||
@ -8,9 +8,10 @@ in pythonPackages.buildPythonApplication rec {
|
|||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "https://launchpad.net/cloud-init/trunk/${version}/+download/cloud-init-${version}.tar.gz";
|
url = "https://launchpad.net/cloud-init/trunk/${version}/+download/cloud-init-${version}.tar.gz";
|
||||||
sha256 = "1mry5zdkfaq952kn1i06wiggc66cqgfp6qgnlpk0mr7nnwpd53wy";
|
sha256 = "0wnl76pdcj754pl99wxx76hkir1s61x0bg0lh27sdgdxy45vivbn";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
patches = [ ./add-nixos-support.patch ];
|
||||||
patchPhase = ''
|
patchPhase = ''
|
||||||
patchShebangs ./tools
|
patchShebangs ./tools
|
||||||
|
|
||||||
@ -19,15 +20,17 @@ in pythonPackages.buildPythonApplication rec {
|
|||||||
--replace /etc $out/etc \
|
--replace /etc $out/etc \
|
||||||
--replace /lib/systemd $out/lib/systemd \
|
--replace /lib/systemd $out/lib/systemd \
|
||||||
--replace 'self.init_system = ""' 'self.init_system = "systemd"'
|
--replace 'self.init_system = ""' 'self.init_system = "systemd"'
|
||||||
|
|
||||||
|
patchPhase
|
||||||
'';
|
'';
|
||||||
|
|
||||||
propagatedBuildInputs = with pythonPackages; [ cheetah jinja2 prettytable
|
propagatedBuildInputs = with pythonPackages; [ cheetah jinja2 prettytable
|
||||||
oauth pyserial configobj pyyaml argparse requests jsonpatch ];
|
oauthlib pyserial configobj pyyaml argparse requests jsonpatch ];
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = http://cloudinit.readthedocs.org;
|
homepage = http://cloudinit.readthedocs.org;
|
||||||
description = "Provides configuration and customization of cloud instance";
|
description = "Provides configuration and customization of cloud instance";
|
||||||
maintainers = [ lib.maintainers.madjar ];
|
maintainers = [ lib.maintainers.madjar lib.maintainers.phile314 ];
|
||||||
platforms = lib.platforms.all;
|
platforms = lib.platforms.all;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user