Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F98223355
BuildStepImplementation.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sat, Jan 11, 05:22
Size
3 KB
Mime Type
text/x-php
Expires
Mon, Jan 13, 05:22 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23530228
Attached To
rPH Phabricator
BuildStepImplementation.php
View Options
<?php
abstract
class
BuildStepImplementation
{
private
$settings
;
const
SETTING_TYPE_STRING
=
'string'
;
const
SETTING_TYPE_INTEGER
=
'integer'
;
const
SETTING_TYPE_BOOLEAN
=
'boolean'
;
const
SETTING_TYPE_ARTIFACT
=
'artifact'
;
public
static
function
getImplementations
()
{
$symbols
=
id
(
new
PhutilSymbolLoader
())
->
setAncestorClass
(
"BuildStepImplementation"
)
->
setConcreteOnly
(
true
)
->
selectAndLoadSymbols
();
return
ipull
(
$symbols
,
'name'
);
}
/**
* The name of the implementation.
*/
abstract
public
function
getName
();
/**
* The generic description of the implementation.
*/
public
function
getGenericDescription
()
{
return
''
;
}
/**
* The description of the implementation, based on the current settings.
*/
public
function
getDescription
()
{
return
''
;
}
/**
* Run the build target against the specified build.
*/
abstract
public
function
execute
(
HarbormasterBuild
$build
,
HarbormasterBuildTarget
$build_target
);
/**
* Gets the settings for this build step.
*/
public
function
getSettings
()
{
return
$this
->
settings
;
}
/**
* Validate the current settings of this build step.
*/
public
function
validate
()
{
return
true
;
}
/**
* Loads the settings for this build step implementation from a build
* step or target.
*/
public
final
function
loadSettings
(
$build_object
)
{
$this
->
settings
=
array
();
$this
->
validateSettingDefinitions
();
foreach
(
$this
->
getSettingDefinitions
()
as
$name
=>
$opt
)
{
$this
->
settings
[
$name
]
=
$build_object
->
getDetail
(
$name
);
}
return
$this
->
settings
;
}
/**
* Validates that the setting definitions for this implementation are valid.
*/
public
final
function
validateSettingDefinitions
()
{
foreach
(
$this
->
getSettingDefinitions
()
as
$name
=>
$opt
)
{
if
(!
isset
(
$opt
[
'type'
]))
{
throw
new
Exception
(
'Setting definition
\'
'
.
$name
.
'
\'
is missing type requirement.'
);
}
}
}
/**
* Return an array of settings for this step implementation.
*/
public
function
getSettingDefinitions
()
{
return
array
();
}
/**
* Return relevant setting instructions as Remarkup.
*/
public
function
getSettingRemarkupInstructions
()
{
return
null
;
}
/**
* Return the name of artifacts produced by this command.
*
* Something like:
*
* return array(
* 'some_name_input_by_user' => 'host');
*
* Future steps will calculate all available artifact mappings
* before them and filter on the type.
*
* @return array The mappings of artifact names to their types.
*/
public
function
getArtifactMappings
()
{
return
array
();
}
/**
* Returns a list of all artifacts made available by previous build steps.
*/
public
static
function
getAvailableArtifacts
(
HarbormasterBuildPlan
$build_plan
,
HarbormasterBuildStep
$current_build_step
,
$artifact_type
)
{
$build_steps
=
$build_plan
->
loadOrderedBuildSteps
();
$previous_implementations
=
array
();
foreach
(
$build_steps
as
$build_step
)
{
if
(
$build_step
->
getPHID
()
===
$current_build_step
->
getPHID
())
{
break
;
}
$previous_implementations
[]
=
$build_step
->
getStepImplementation
();
}
$artifact_arrays
=
mpull
(
$previous_implementations
,
'getArtifactMappings'
);
$artifacts
=
array
();
foreach
(
$artifact_arrays
as
$array
)
{
foreach
(
$array
as
$name
=>
$type
)
{
if
(
$type
!==
$artifact_type
)
{
continue
;
}
$artifacts
[
$name
]
=
$type
;
}
}
return
$artifacts
;
}
}
Event Timeline
Log In to Comment