Merge pull request #6543 from thedrow/lxc-root-path
Determine lxc root according to the running user
This commit is contained in:
commit
57dd1c3ca2
|
@ -4,7 +4,9 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
"os/user"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
"github.com/hashicorp/packer/helper/multistep"
|
"github.com/hashicorp/packer/helper/multistep"
|
||||||
|
@ -19,7 +21,16 @@ func (s *stepExport) Run(_ context.Context, state multistep.StateBag) multistep.
|
||||||
|
|
||||||
name := config.ContainerName
|
name := config.ContainerName
|
||||||
|
|
||||||
containerDir := fmt.Sprintf("/var/lib/lxc/%s", name)
|
lxc_dir := "/var/lib/lxc"
|
||||||
|
user, err := user.Current()
|
||||||
|
if err != nil {
|
||||||
|
log.Print("Cannot find current user. Falling back to /var/lib/lxc...")
|
||||||
|
}
|
||||||
|
if user.Uid != "0" && user.HomeDir != "" {
|
||||||
|
lxc_dir = filepath.Join(user.HomeDir, ".local", "share", "lxc")
|
||||||
|
}
|
||||||
|
|
||||||
|
containerDir := filepath.Join(lxc_dir, name)
|
||||||
outputPath := filepath.Join(config.OutputDir, "rootfs.tar.gz")
|
outputPath := filepath.Join(config.OutputDir, "rootfs.tar.gz")
|
||||||
configFilePath := filepath.Join(config.OutputDir, "lxc-config")
|
configFilePath := filepath.Join(config.OutputDir, "lxc-config")
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,8 @@ package lxc
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"log"
|
||||||
|
"os/user"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
"github.com/hashicorp/packer/helper/multistep"
|
"github.com/hashicorp/packer/helper/multistep"
|
||||||
|
@ -19,6 +21,13 @@ func (s *stepLxcCreate) Run(_ context.Context, state multistep.StateBag) multist
|
||||||
|
|
||||||
// TODO: read from env
|
// TODO: read from env
|
||||||
lxc_dir := "/var/lib/lxc"
|
lxc_dir := "/var/lib/lxc"
|
||||||
|
user, err := user.Current()
|
||||||
|
if err != nil {
|
||||||
|
log.Print("Cannot find current user. Falling back to /var/lib/lxc...")
|
||||||
|
}
|
||||||
|
if user.Uid != "0" && user.HomeDir != "" {
|
||||||
|
lxc_dir = filepath.Join(user.HomeDir, ".local", "share", "lxc")
|
||||||
|
}
|
||||||
rootfs := filepath.Join(lxc_dir, name, "rootfs")
|
rootfs := filepath.Join(lxc_dir, name, "rootfs")
|
||||||
|
|
||||||
if config.PackerForce {
|
if config.PackerForce {
|
||||||
|
|
Loading…
Reference in New Issue