@ -54,7 +54,7 @@ type serverConfig struct {
LogFile string ` toml:"log_file" `
LogFile string ` toml:"log_file" `
}
}
func NewRemoteBuildxController ( ctx context . Context , dockerCli command . Cli , opts control . ControlOptions ) ( control . BuildxController , error ) {
func NewRemoteBuildxController ( ctx context . Context , dockerCli command . Cli , opts control . ControlOptions , logger progress . SubLogger ) ( control . BuildxController , error ) {
rootDir := opts . Root
rootDir := opts . Root
if rootDir == "" {
if rootDir == "" {
rootDir = rootDataDir ( dockerCli )
rootDir = rootDataDir ( dockerCli )
@ -74,27 +74,32 @@ func NewRemoteBuildxController(ctx context.Context, dockerCli command.Cli, opts
}
}
// start buildx server via subcommand
// start buildx server via subcommand
logrus. Info ( "no buildx server found; launching..." )
err = logger . Wrap ( "no buildx server found; launching..." , func ( ) error {
launchFlags := [ ] string { }
launchFlags := [ ] string { }
if opts . ServerConfig != "" {
if opts . ServerConfig != "" {
launchFlags = append ( launchFlags , "--config" , opts . ServerConfig )
launchFlags = append ( launchFlags , "--config" , opts . ServerConfig )
}
}
logFile , err := getLogFilePath ( dockerCli , opts . ServerConfig )
logFile , err := getLogFilePath ( dockerCli , opts . ServerConfig )
if err != nil {
if err != nil {
return nil , err
return err
}
}
wait , err := launch ( ctx , logFile , append ( [ ] string { serveCommandName } , launchFlags ... ) ... )
wait , err := launch ( ctx , logFile , append ( [ ] string { serveCommandName } , launchFlags ... ) ... )
if err != nil {
if err != nil {
return nil , err
return err
}
}
go wait ( )
go wait ( )
// wait for buildx server to be ready
// wait for buildx server to be ready
ctx2 , cancel = context . WithTimeout ( ctx , 10 * time . Second )
ctx2 , cancel = context . WithTimeout ( ctx , 10 * time . Second )
c , err = newBuildxClientAndCheck ( ctx2 , filepath . Join ( serverRoot , defaultSocketFilename ) )
c , err = newBuildxClientAndCheck ( ctx2 , filepath . Join ( serverRoot , defaultSocketFilename ) )
cancel ( )
cancel ( )
if err != nil {
return errors . Wrap ( err , "cannot connect to the buildx server" )
}
return nil
} )
if err != nil {
if err != nil {
return nil , errors . Wrap ( err , "cannot connect to the buildx server" )
return nil , err
}
}
return & buildxController { c , serverRoot } , nil
return & buildxController { c , serverRoot } , nil
}
}