grim/convey
Clone
Summary
Browse
Changes
Graph
Add new task aws/ecr-login for logging into AWS ECR. Fixed #161
2018-02-13, Gary Kramlich
31cbebf0c277
Add new task aws/ecr-login for logging into AWS ECR. Fixed #161
// Convey
// Copyright 2016-2018 Gary Kramlich <grim@reaperworld.com>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
package
docker
import
(
"github.com/aphistic/gomol"
"bitbucket.org/rw_grim/convey/environment"
"bitbucket.org/rw_grim/convey/path"
"bitbucket.org/rw_grim/convey/state"
"bitbucket.org/rw_grim/convey/tasks"
"bitbucket.org/rw_grim/convey/yaml"
)
// Import represents an import task which imports files from the host to the
// workspace.
type
Import
struct
{
Files
yaml
.
StringOrSlice
`yaml:"files"`
}
// Execute runs the import task.
func
(
i
*
Import
)
Execute
(
name
string
,
logger
*
gomol
.
LogAdapter
,
env
[]
string
,
st
*
state
.
State
)
error
{
fullEnv
:=
environment
.
Merge
(
env
,
st
.
GetEnv
())
files
,
err
:=
st
.
MapSlice
(
i
.
Files
,
fullEnv
)
if
err
!=
nil
{
return
err
}
for
_
,
file
:=
range
files
{
file
,
err
:=
environment
.
Mapper
(
file
,
fullEnv
)
if
err
!=
nil
{
return
err
}
src
,
dest
:=
tasks
.
ParseFilePath
(
""
,
file
)
// make sure the file we're import is in our build context
realSrc
,
err
:=
path
.
Traverses
(
st
.
CfgPath
,
src
)
if
err
!=
nil
{
return
err
}
cmdv
:=
[]
string
{
"cp"
,
realSrc
,
st
.
Workspace
.
Name
()
+
":/workspace/"
+
dest
,
}
if
err
:=
Docker
(
name
,
cmdv
,
st
);
err
!=
nil
{
return
err
}
}
return
nil
}
// New creates a new import task.
func
(
i
*
Import
)
New
()
tasks
.
Task
{
return
&
Import
{}
}
// Valid validates the import task.
func
(
i
*
Import
)
Valid
()
error
{
if
len
(
i
.
Files
)
==
0
{
return
errNoFiles
}
return
nil
}