package rpc

import (
	"github.com/mitchellh/packer/packer"
	"net/rpc"
)

// An implementation of packer.Artifact where the artifact is actually
// available over an RPC connection.
type artifact struct {
	client *rpc.Client
}

// ArtifactServer wraps a packer.Artifact implementation and makes it
// exportable as part of a Golang RPC server.
type ArtifactServer struct {
	artifact packer.Artifact
}

func Artifact(client *rpc.Client) *artifact {
	return &artifact{client}
}

func (a *artifact) BuilderId() (result string) {
	a.client.Call("Artifact.BuilderId", new(interface{}), &result)
	return
}

func (a *artifact) Files() (result []string) {
	a.client.Call("Artifact.Files", new(interface{}), &result)
	return
}

func (a *artifact) Id() (result string) {
	a.client.Call("Artifact.Id", new(interface{}), &result)
	return
}

func (a *artifact) String() (result string) {
	a.client.Call("Artifact.String", new(interface{}), &result)
	return
}

func (a *artifact) Destroy() error {
	var result error
	if err := a.client.Call("Artifact.Destroy", new(interface{}), &result); err != nil {
		return err
	}

	return result
}

func (s *ArtifactServer) BuilderId(args *interface{}, reply *string) error {
	*reply = s.artifact.BuilderId()
	return nil
}

func (s *ArtifactServer) Files(args *interface{}, reply *[]string) error {
	*reply = s.artifact.Files()
	return nil
}

func (s *ArtifactServer) Id(args *interface{}, reply *string) error {
	*reply = s.artifact.Id()
	return nil
}

func (s *ArtifactServer) String(args *interface{}, reply *string) error {
	*reply = s.artifact.String()
	return nil
}

func (s *ArtifactServer) Destroy(args *interface{}, reply *error) error {
	err := s.artifact.Destroy()
	if err != nil {
		err = NewBasicError(err)
	}

	*reply = err
	return nil
}