summaryrefslogtreecommitdiff
path: root/hscript
diff options
context:
space:
mode:
authorA. Wilcox <AWilcox@Wilcox-Tech.com>2019-11-06 00:57:00 -0600
committerA. Wilcox <AWilcox@Wilcox-Tech.com>2019-11-06 00:57:00 -0600
commitada546b6002360169570a72c83fadc574b936c18 (patch)
tree85305bc68600abdfbbc743eea8622537b5379bad /hscript
parented351160f94bfff12fadbceb44a2f85604dfb957 (diff)
downloadhorizon-ada546b6002360169570a72c83fadc574b936c18.tar.gz
horizon-ada546b6002360169570a72c83fadc574b936c18.tar.bz2
horizon-ada546b6002360169570a72c83fadc574b936c18.tar.xz
horizon-ada546b6002360169570a72c83fadc574b936c18.zip
hscript: Implement Runner.Execute.netaddress.OpenRC
Diffstat (limited to 'hscript')
-rw-r--r--hscript/script_e.cc36
1 files changed, 36 insertions, 0 deletions
diff --git a/hscript/script_e.cc b/hscript/script_e.cc
index 27d5fbf..b494698 100644
--- a/hscript/script_e.cc
+++ b/hscript/script_e.cc
@@ -12,6 +12,8 @@
#include <algorithm>
#include <fstream>
+#include <set>
+#include <string>
#ifdef HAS_INSTALL_ENV
# include <parted/parted.h>
#endif /* HAS_INSTALL_ENV */
@@ -26,6 +28,7 @@ namespace Horizon {
bool Script::execute() const {
bool success;
error_code ec;
+ std::set<std::string> ifaces;
/* assume create_directory will give us the error if removal fails */
if(fs::exists("/tmp/horizon", ec)) {
@@ -250,6 +253,8 @@ bool Script::execute() const {
if(!addr->execute(opts)) {
EXECUTE_FAILURE("netaddress");
/* "Soft" error. Not fatal. */
+ } else {
+ ifaces.insert(addr->iface());
}
if(addr->type() == NetAddress::DHCP) dhcp = true;
}
@@ -460,6 +465,37 @@ bool Script::execute() const {
/**************** POST PACKAGE METADATA ****************/
output_step_start("post-metadata");
+ if(internal->packages.find("netifrc") != internal->packages.end() &&
+ !internal->addresses.empty()) {
+ /* REQ: Runner.Execute.netaddress.OpenRC */
+ if(opts.test(Simulate)) {
+ for(auto &iface : ifaces) {
+ std::cout << "ln -s /etc/init.d/net.lo /target/etc/init.d/net."
+ << iface << std::endl;
+ std::cout << "ln -s /etc/init.d/net." << iface
+ << " /target/etc/runlevels/default/net." << iface
+ << std::endl;
+ }
+ } else {
+ for(auto &iface : ifaces) {
+ fs::create_symlink("/etc/init.d/net.lo",
+ "/target/etc/init.d/net." + iface, ec);
+ if(ec) {
+ output_error("internal", "could not set up networking on "
+ + iface, ec.message());
+ } else {
+ fs::create_symlink("/etc/init.d/net." + iface,
+ "/target/etc/runlevels/default/net." +
+ iface, ec);
+ if(ec) {
+ output_error("internal", "could not auto-start "
+ "networking on" + iface, ec.message());
+ }
+ }
+ }
+ }
+ }
+
if(!internal->rootpw->execute(opts)) {
EXECUTE_FAILURE("rootpw");
return false;