This changeset performs the following: - Updates `masterzen/winrm` vendor to include change from (https://github.com/masterzen/winrm/pull/73). - Removes `masterzen/xmlpath` dependency, as it is licensed under the LGPL license. - Updates `dylanmei/winrmtest` vendor to include change from (https://github.com/dylanmei/winrmtest/pull/4). - Updates `packer-community/winrmcp` vendor to include the removal of the `masterzen/winrm/winrm` sub-class as a result of the `winrm` CLI tool being removed from the `masterzen/winrm` repository. - Updates nested dependencies as a result of the above vendor changes. - Refactors `parallels/driver_9` to use `goxpath` instead of `xmlpath`, as `xmlpath` is licensed under LGPL. - Adds a basic unit test for the refactor work in `parallels/driver_9` to confirm functionality. This should completely remove any LGPL licensed dependencies inside of the Packer project. ``` $ make test /home/jake/src/go/src/github.com/hashicorp/packer/scripts/gofmtcheck.sh $(find . -not -path "./vendor/*" -name "*.go") ==> Checking that code complies with gofmt requirements... Check passed. ok github.com/hashicorp/packer 0.044s ok github.com/hashicorp/packer/builder/alicloud/ecs 0.055s ok github.com/hashicorp/packer/builder/amazon/chroot 0.040s ok github.com/hashicorp/packer/builder/amazon/common 0.021s ok github.com/hashicorp/packer/builder/amazon/ebs 0.016s ok github.com/hashicorp/packer/builder/amazon/ebssurrogate 0.015s ok github.com/hashicorp/packer/builder/amazon/ebsvolume 0.014s ok github.com/hashicorp/packer/builder/amazon/instance 0.058s ok github.com/hashicorp/packer/builder/azure/arm 2.833s ok github.com/hashicorp/packer/builder/azure/common 0.018s ? github.com/hashicorp/packer/builder/azure/common/constants [no test files] ? github.com/hashicorp/packer/builder/azure/common/lin [no test files] ? github.com/hashicorp/packer/builder/azure/common/logutil [no test files] ok github.com/hashicorp/packer/builder/azure/common/template 0.038s ok github.com/hashicorp/packer/builder/azure/pkcs12 0.120s ok github.com/hashicorp/packer/builder/azure/pkcs12/rc2 0.020s ok github.com/hashicorp/packer/builder/cloudstack 0.038s ok github.com/hashicorp/packer/builder/digitalocean 0.015s ok github.com/hashicorp/packer/builder/docker 0.028s ok github.com/hashicorp/packer/builder/file 0.029s ok github.com/hashicorp/packer/builder/googlecompute 3.162s ok github.com/hashicorp/packer/builder/hyperv/common 0.006s ok github.com/hashicorp/packer/builder/hyperv/iso 0.042s ok github.com/hashicorp/packer/builder/null 0.018s ok github.com/hashicorp/packer/builder/oneandone 0.022s ok github.com/hashicorp/packer/builder/openstack 0.052s ok github.com/hashicorp/packer/builder/parallels/common 2.549s ok github.com/hashicorp/packer/builder/parallels/iso 0.050s ok github.com/hashicorp/packer/builder/parallels/pvm 0.033s ok github.com/hashicorp/packer/builder/profitbricks 0.023s ok github.com/hashicorp/packer/builder/qemu 0.039s ok github.com/hashicorp/packer/builder/triton 0.018s ok github.com/hashicorp/packer/builder/virtualbox/common 5.533s ok github.com/hashicorp/packer/builder/virtualbox/iso 0.044s ok github.com/hashicorp/packer/builder/virtualbox/ovf 0.012s ok github.com/hashicorp/packer/builder/vmware/common 5.325s ok github.com/hashicorp/packer/builder/vmware/iso 0.076s ok github.com/hashicorp/packer/builder/vmware/vmx 0.010s ok github.com/hashicorp/packer/command 0.062s ok github.com/hashicorp/packer/common 0.053s ok github.com/hashicorp/packer/common/json 0.003s [no tests to run] ok github.com/hashicorp/packer/common/powershell 0.015s ? github.com/hashicorp/packer/common/powershell/hyperv [no test files] ? github.com/hashicorp/packer/common/ssh [no test files] ok github.com/hashicorp/packer/common/uuid 0.010s ok github.com/hashicorp/packer/communicator/none 0.008s ok github.com/hashicorp/packer/communicator/ssh 0.068s ok github.com/hashicorp/packer/communicator/winrm 0.046s ok github.com/hashicorp/packer/fix 0.005s ok github.com/hashicorp/packer/helper/builder/testing 0.007s ok github.com/hashicorp/packer/helper/communicator 0.013s ok github.com/hashicorp/packer/helper/config 0.004s ? github.com/hashicorp/packer/helper/enumflag [no test files] ok github.com/hashicorp/packer/helper/flag-kv 0.009s ok github.com/hashicorp/packer/helper/flag-slice 0.006s ok github.com/hashicorp/packer/packer 0.219s ok github.com/hashicorp/packer/packer/plugin 0.233s ok github.com/hashicorp/packer/packer/rpc 0.141s ok github.com/hashicorp/packer/plugin/example 0.008s [no tests to run] ? github.com/hashicorp/packer/post-processor/alicloud-import [no test files] ? github.com/hashicorp/packer/post-processor/amazon-import [no test files] ok github.com/hashicorp/packer/post-processor/artifice 0.003s [no tests to run] ok github.com/hashicorp/packer/post-processor/atlas 0.018s ok github.com/hashicorp/packer/post-processor/checksum 0.015s ok github.com/hashicorp/packer/post-processor/compress 0.047s ok github.com/hashicorp/packer/post-processor/docker-import 0.012s ok github.com/hashicorp/packer/post-processor/docker-push 0.012s ok github.com/hashicorp/packer/post-processor/docker-save 0.008s ok github.com/hashicorp/packer/post-processor/docker-tag 0.008s ok github.com/hashicorp/packer/post-processor/googlecompute-export 0.015s [no tests to run] ? github.com/hashicorp/packer/post-processor/manifest [no test files] ok github.com/hashicorp/packer/post-processor/shell-local 0.028s ok github.com/hashicorp/packer/post-processor/vagrant 0.030s ok github.com/hashicorp/packer/post-processor/vagrant-cloud 0.028s ok github.com/hashicorp/packer/post-processor/vsphere 0.014s ok github.com/hashicorp/packer/provisioner 0.011s ok github.com/hashicorp/packer/provisioner/ansible 0.140s ok github.com/hashicorp/packer/provisioner/ansible-local 0.056s ok github.com/hashicorp/packer/provisioner/chef-client 0.050s ok github.com/hashicorp/packer/provisioner/chef-solo 0.061s ok github.com/hashicorp/packer/provisioner/converge 0.018s ok github.com/hashicorp/packer/provisioner/file 0.015s ok github.com/hashicorp/packer/provisioner/powershell 0.168s ok github.com/hashicorp/packer/provisioner/puppet-masterless 0.008s ok github.com/hashicorp/packer/provisioner/puppet-server 0.031s ok github.com/hashicorp/packer/provisioner/salt-masterless 0.010s ok github.com/hashicorp/packer/provisioner/shell 0.010s ok github.com/hashicorp/packer/provisioner/shell-local 0.037s ok github.com/hashicorp/packer/provisioner/windows-restart 0.180s ok github.com/hashicorp/packer/provisioner/windows-shell 0.159s ? github.com/hashicorp/packer/scripts [no test files] ok github.com/hashicorp/packer/template 0.008s ok github.com/hashicorp/packer/template/interpolate 0.004s ? github.com/hashicorp/packer/version [no test files] ```
161 lines
3.8 KiB
Go
161 lines
3.8 KiB
Go
package winrmtest
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/base64"
|
|
"fmt"
|
|
"net/http"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/antchfx/xquery/xml"
|
|
"github.com/satori/go.uuid"
|
|
)
|
|
|
|
type wsman struct {
|
|
commands []*command
|
|
identitySeed int
|
|
}
|
|
|
|
type command struct {
|
|
id string
|
|
matcher MatcherFunc
|
|
handler CommandFunc
|
|
}
|
|
|
|
func (w *wsman) HandleCommand(m MatcherFunc, f CommandFunc) string {
|
|
id := uuid.NewV4().String()
|
|
w.commands = append(w.commands, &command{
|
|
id: id,
|
|
matcher: m,
|
|
handler: f,
|
|
})
|
|
|
|
return id
|
|
}
|
|
|
|
func (w *wsman) CommandByText(cmd string) *command {
|
|
for _, c := range w.commands {
|
|
if c.matcher(cmd) {
|
|
return c
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (w *wsman) CommandByID(id string) *command {
|
|
for _, c := range w.commands {
|
|
if c.id == id {
|
|
return c
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (w *wsman) ServeHTTP(rw http.ResponseWriter, r *http.Request) {
|
|
rw.Header().Add("Content-Type", "application/soap+xml")
|
|
|
|
defer r.Body.Close()
|
|
env, err := xmlquery.Parse(r.Body)
|
|
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
action := readAction(env)
|
|
switch {
|
|
case strings.HasSuffix(action, "transfer/Create"):
|
|
// create a new shell
|
|
|
|
rw.Write([]byte(`
|
|
<env:Envelope xmlns:env="http://www.w3.org/2003/05/soap-envelope" xmlns:rsp="http://schemas.microsoft.com/wbem/wsman/1/windows/shell">
|
|
<rsp:ShellId>123</rsp:ShellId>
|
|
</env:Envelope>`))
|
|
|
|
case strings.HasSuffix(action, "shell/Command"):
|
|
// execute on behalf of the client
|
|
text := readCommand(env)
|
|
cmd := w.CommandByText(text)
|
|
|
|
if cmd == nil {
|
|
fmt.Printf("I don't know this command: Command=%s\n", text)
|
|
rw.WriteHeader(http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
rw.Write([]byte(fmt.Sprintf(`
|
|
<env:Envelope xmlns:env="http://www.w3.org/2003/05/soap-envelope" xmlns:rsp="http://schemas.microsoft.com/wbem/wsman/1/windows/shell">
|
|
<rsp:CommandId>%s</rsp:CommandId>
|
|
</env:Envelope>`, cmd.id)))
|
|
|
|
case strings.HasSuffix(action, "shell/Receive"):
|
|
// client ready to receive the results
|
|
|
|
id := readCommandIDFromDesiredStream(env)
|
|
cmd := w.CommandByID(id)
|
|
|
|
if cmd == nil {
|
|
fmt.Printf("I don't know this command: CommandId=%s\n", id)
|
|
rw.WriteHeader(http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
stdout := new(bytes.Buffer)
|
|
stderr := new(bytes.Buffer)
|
|
result := cmd.handler(stdout, stderr)
|
|
content := base64.StdEncoding.EncodeToString(stdout.Bytes())
|
|
|
|
rw.Write([]byte(fmt.Sprintf(`
|
|
<env:Envelope xmlns:env="http://www.w3.org/2003/05/soap-envelope" xmlns:rsp="http://schemas.microsoft.com/wbem/wsman/1/windows/shell">
|
|
<rsp:ReceiveResponse>
|
|
<rsp:Stream Name="stdout" CommandId="%s">%s</rsp:Stream>
|
|
<rsp:Stream Name="stdout" CommandId="%s" End="true"></rsp:Stream>
|
|
<rsp:Stream Name="stderr" CommandId="%s" End="true"></rsp:Stream>
|
|
<rsp:CommandState State="http://schemas.microsoft.com/wbem/wsman/1/windows/shell/CommandState/Done">
|
|
<rsp:ExitCode>%d</rsp:ExitCode>
|
|
</rsp:CommandState>
|
|
</rsp:ReceiveResponse>
|
|
</env:Envelope>`, id, content, id, id, result)))
|
|
|
|
case strings.HasSuffix(action, "shell/Signal"):
|
|
// end of the shell command
|
|
rw.WriteHeader(http.StatusOK)
|
|
case strings.HasSuffix(action, "transfer/Delete"):
|
|
// end of the session
|
|
rw.WriteHeader(http.StatusOK)
|
|
default:
|
|
fmt.Printf("I don't know this action: %s\n", action)
|
|
rw.WriteHeader(http.StatusInternalServerError)
|
|
}
|
|
}
|
|
|
|
func readAction(env *xmlquery.Node) string {
|
|
xpath := xmlquery.FindOne(env, "//a:Action")
|
|
if xpath == nil {
|
|
return ""
|
|
}
|
|
|
|
return xpath.InnerText()
|
|
}
|
|
|
|
func readCommand(env *xmlquery.Node) string {
|
|
xpath := xmlquery.FindOne(env, "//rsp:Command")
|
|
if xpath == nil {
|
|
return ""
|
|
}
|
|
|
|
if unquoted, err := strconv.Unquote(xpath.InnerText()); err == nil {
|
|
return unquoted
|
|
}
|
|
return xpath.InnerText()
|
|
}
|
|
|
|
func readCommandIDFromDesiredStream(env *xmlquery.Node) string {
|
|
xpath := xmlquery.FindOne(env, "//rsp:DesiredStream")
|
|
if xpath == nil {
|
|
return ""
|
|
}
|
|
|
|
return xpath.SelectAttr("CommandId")
|
|
}
|