jsonnet-drone/deploy.libsonnet

72 lines
1.8 KiB
Plaintext
Raw Normal View History

2020-08-15 09:43:20 +00:00
local build = import 'lib/build.libsonnet';
local images = import 'lib/images.libsonnet';
2020-08-19 20:12:35 +00:00
local environment = import 'lib/node_modules/@sigyl/jsonnet-drone-environment/environment.libsonnet';
2020-08-19 20:01:46 +00:00
local compose = import 'lib/node_modules/@sigyl/jsonnet-compose/compose.libsonnet';
2020-08-15 09:43:20 +00:00
local util = import 'lib/util.libsonnet';
local login = import 'lib/login.libsonnet';
2020-08-15 09:43:20 +00:00
function(config)
function(
buildSecrets,
publicSecrets,
secretSecrets,
droneSecrets,
)
{
kind: 'pipeline',
type: 'docker',
name: 'deploy',
clone: {
disable: false,
depth: 0,
},
steps:[
images(config).scp(
'/%(root)s/%(name)s' % config
2020-08-15 09:43:20 +00:00
),
compose(
std.map(
function(secret) environment.envSet(secret),
publicSecrets + secretSecrets + buildSecrets,
),
)(
images(config).ssh{
name: 'deploy',
settings +: {
envs +: std.map(
environment.env,
droneSecrets,
),
script +:
std.map(
function(secret)
'export %(env)s=$${%(env)s}' % {
env: environment.environment(secret)
},
secretSecrets + publicSecrets + buildSecrets + droneSecrets,
) +
[
'set -e',
'export NAME=%s' % config.name,
'export ROOT=%s' % config.root,
'cd /%(root)s/%(name)s' % config,
login,
'sh .drone/pull.sh',
'sh .drone/deploy.sh',
]
}
},
),
],
} {
trigger +: {
event +: [
'promote',
],
target +: [
'deploy',
],
},
}