本文整理匯總了Golang中github.com/bitrise-io/go-utils/colorstring.Blue函數的典型用法代碼示例。如果您正苦於以下問題:Golang Blue函數的具體用法?Golang Blue怎麽用?Golang Blue使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Blue函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: GuideTextForStart
// GuideTextForStart ...
func GuideTextForStart() string {
guide := colorstring.Blue("Fork the StepLib repository") + " you want to share your Step in.\n" +
` You can find the main ("official") StepLib repository at: ` + colorstring.Green("https://github.com/bitrise-io/bitrise-steplib") + `
` + colorstring.Yellow("Note") + `: You can use any StepLib repository you like,
the StepLib system is decentralized, you don't have to work with the main StepLib repository
if you don't want to. Feel free to maintain and use your own (or your team's) Step Library.
`
return guide
}
示例2: GuideTextForAudit
// GuideTextForAudit ...
func GuideTextForAudit(toolMode bool) string {
name := "stepman"
if toolMode {
name = "bitrise"
}
guide := "You can call " + colorstring.Blue("'"+name+" audit'") + `,
to perform a complete health-check on your StepLib before submitting your Pull Request.
This can help you catch issues which might prevent your Step to be accepted.
`
return guide
}
示例3: triggerCheck
func triggerCheck(c *cli.Context) {
format := c.String(OuputFormatKey)
if format == "" {
format = configs.OutputFormatRaw
} else if !(format == configs.OutputFormatRaw || format == configs.OutputFormatJSON) {
registerFatal(fmt.Sprintf("Invalid format: %s", format), configs.OutputFormatJSON)
}
// Config validation
bitriseConfig, err := CreateBitriseConfigFromCLIParams(c)
if err != nil {
registerFatal(fmt.Sprintf("Failed to create config, err: %s", err), format)
}
// Trigger filter validation
triggerPattern := ""
if len(c.Args()) < 1 {
registerFatal("No trigger pattern specified", format)
} else {
triggerPattern = c.Args()[0]
}
if triggerPattern == "" {
registerFatal("No trigger pattern specified", format)
}
workflowToRunID, err := GetWorkflowIDByPattern(bitriseConfig, triggerPattern)
if err != nil {
registerFatal(err.Error(), format)
}
switch format {
case configs.OutputFormatRaw:
fmt.Printf("%s -> %s\n", triggerPattern, colorstring.Blue(workflowToRunID))
break
case configs.OutputFormatJSON:
triggerModel := map[string]string{
"pattern": triggerPattern,
"workflow": workflowToRunID,
}
bytes, err := json.Marshal(triggerModel)
if err != nil {
registerFatal(fmt.Sprintf("Failed to parse trigger model, err: %s", err), format)
}
fmt.Println(string(bytes))
break
default:
registerFatal(fmt.Sprintf("Invalid format: %s", format), configs.OutputFormatJSON)
}
}
示例4: printRawStepInfo
func printRawStepInfo(stepInfo models.StepInfoModel, isShort, isLocal bool) {
if isLocal {
fmt.Println(colorstring.Bluef("Local step info, yml path (%s):", stepInfo.StepLib))
} else {
fmt.Println(colorstring.Bluef("Step info in StepLib (%s):", stepInfo.StepLib))
}
if stepInfo.GlobalInfo.RemovalDate != "" {
fmt.Println("")
fmt.Println(colorstring.Red("This step is deprecated!"))
fmt.Printf("%s %s\n", colorstring.Red("removal date:"), stepInfo.GlobalInfo.RemovalDate)
if stepInfo.GlobalInfo.DeprecateNotes != "" {
fmt.Printf("%s\n%s\n", colorstring.Red("deprecate notes:"), stepInfo.GlobalInfo.DeprecateNotes)
}
}
if stepInfo.ID != "" {
fmt.Printf("%s: %s\n", colorstring.Blue("ID"), stepInfo.ID)
}
if stepInfo.Version != "" {
fmt.Printf("%s: %s\n", colorstring.Blue("version"), stepInfo.Version)
}
if stepInfo.Latest != "" {
fmt.Printf("%s: %s\n", colorstring.Blue("latest"), stepInfo.Latest)
}
if !isShort {
fmt.Printf("%s: %s\n", colorstring.Blue("source"), stepInfo.Source)
fmt.Printf("%s:\n", colorstring.Blue("description"))
fmt.Printf("%s\n", stepInfo.Description)
fmt.Println()
if len(stepInfo.Inputs) > 0 {
fmt.Printf("%s:\n", colorstring.Blue("inputs"))
for _, input := range stepInfo.Inputs {
printRawEnvInfo(input)
}
}
if len(stepInfo.Outputs) > 0 {
if len(stepInfo.Inputs) > 0 {
fmt.Println()
}
fmt.Printf("%s:\n", colorstring.Blue("outputs"))
for _, output := range stepInfo.Outputs {
printRawEnvInfo(output)
}
}
}
fmt.Println()
fmt.Println()
}
示例5: printRawValidation
func printRawValidation(validation ValidationModel) error {
validConfig := true
if validation.Config != nil {
fmt.Println(colorstring.Blue("Config validation result:"))
configValidation := *validation.Config
if configValidation.IsValid {
fmt.Printf("is valid: %s\n", colorstring.Greenf("%v", configValidation.IsValid))
} else {
fmt.Printf("is valid: %s\n", colorstring.Redf("%v", configValidation.IsValid))
fmt.Printf("error: %s\n", colorstring.Red(configValidation.Error))
validConfig = false
}
fmt.Println()
}
validSecrets := true
if validation.Secrets != nil {
fmt.Println(colorstring.Blue("Secret validation result:"))
secretValidation := *validation.Secrets
if secretValidation.IsValid {
fmt.Printf("is valid: %s\n", colorstring.Greenf("%v", secretValidation.IsValid))
} else {
fmt.Printf("is valid: %s\n", colorstring.Redf("%v", secretValidation.IsValid))
fmt.Printf("error: %s\n", colorstring.Red(secretValidation.Error))
validSecrets = false
}
}
if !validConfig && !validSecrets {
return errors.New("Config and secrets are invalid")
} else if !validConfig {
return errors.New("Config is invalid")
} else if !validSecrets {
return errors.New("Secret is invalid")
}
return nil
}
示例6: GuideTextForShareFinish
// GuideTextForShareFinish ...
func GuideTextForShareFinish(toolMode bool) string {
name := "stepman"
if toolMode {
name = "bitrise"
}
guide := `Almost done! You should review your Step's step.yml file (the one added to the local StepLib),
and once you're happy with it call: ` + colorstring.Blue("'"+name+" share finish'") + `
This will commit & push the step.yml ` + colorstring.Yellow("into your forked StepLib repository") + `.
`
return guide
}
示例7: GuideTextForShareStart
// GuideTextForShareStart ...
func GuideTextForShareStart(toolMode bool) string {
name := "stepman"
if toolMode {
name = "bitrise"
}
guide := "Call " + colorstring.Blue("'"+name+" share start -c STEPLIB_REPO_FORK_GIT_URL'") + ", with the " + colorstring.Yellow("git clone url") + " of " + colorstring.Yellow("your forked StepLib repository") + ".\n" +
` This will prepare your forked StepLib locally for sharing.
For example, if you want to share your Step in the main StepLib repository you should call:
` + colorstring.Green(""+name+" share start -c https://github.com/[your-username]/bitrise-steplib.git") + `
`
return guide
}
示例8: GuideTextForShareCreate
// GuideTextForShareCreate ...
func GuideTextForShareCreate(toolMode bool) string {
name := "stepman"
if toolMode {
name = "bitrise"
}
guide := "Next, call " + colorstring.Blue("'"+name+" share create --tag STEP_VERSION_TAG --git STEP_GIT_URI --stepid STEP_ID'") + `,
to add your Step to your forked StepLib repository (locally).
This will copy the required step.yml file from your Step's repository.
This is all what's required to add your step (or a new version) to a StepLib.
` + colorstring.Yellow("Important") + `: You have to add the (version) tag to your Step's repository before you would call this!
You can do that at: https://github.com/[your-username]/[step-repository]/tags
An example call:
` + colorstring.Green(""+name+" share create --tag 1.0.0 --git https://github.com/[your-username]/[step-repository].git --stepid my-awesome-step") + `
` + colorstring.Yellow("Note") + `: You'll still be able to modify the step.yml in the StepLib after this.
`
return guide
}
示例9: activateAndRunSteps
func activateAndRunSteps(workflow models.WorkflowModel, defaultStepLibSource string, buildRunResults models.BuildRunResultsModel, environments *[]envmanModels.EnvironmentItemModel, isLastWorkflow bool) models.BuildRunResultsModel {
log.Debugln("[BITRISE_CLI] - Activating and running steps")
var stepStartTime time.Time
registerStepRunResults := func(step stepmanModels.StepModel, resultCode, exitCode int, err error, isLastStep bool) {
if step.Title == nil {
log.Error("Step title is nil, should not happend!")
step.Title = pointers.NewStringPtr("ERROR! Step title is nil!")
}
stepResults := models.StepRunResultsModel{
StepName: *step.Title,
Status: resultCode,
Idx: buildRunResults.ResultsCount(),
RunTime: time.Now().Sub(stepStartTime),
Error: err,
ExitCode: exitCode,
}
switch resultCode {
case models.StepRunStatusCodeSuccess:
buildRunResults.SuccessSteps = append(buildRunResults.SuccessSteps, stepResults)
break
case models.StepRunStatusCodeFailed:
log.Errorf("Step (%s) failed, error: (%v)", *step.Title, err)
buildRunResults.FailedSteps = append(buildRunResults.FailedSteps, stepResults)
break
case models.StepRunStatusCodeFailedSkippable:
log.Warnf("Step (%s) failed, but was marked as skippable, error: (%v)", *step.Title, err)
buildRunResults.FailedSkippableSteps = append(buildRunResults.FailedSkippableSteps, stepResults)
break
case models.StepRunStatusCodeSkipped:
log.Warnf("A previous step failed, and this step (%s) was not marked as IsAlwaysRun, skipped", *step.Title)
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
case models.StepRunStatusCodeSkippedWithRunIf:
log.Warn("The step's (" + *step.Title + ") Run-If expression evaluated to false - skipping")
log.Info("The Run-If expression was: ", colorstring.Blue(*step.RunIf))
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
default:
log.Error("Unkown result code")
return
}
bitrise.PrintStepSummary(stepResults, isLastStep)
}
registerStepListItemRunResults := func(stepListItem models.StepListItemModel, resultCode, exitCode int, err error, isLastStep bool) {
name := ""
for key := range stepListItem {
name = key
break
}
stepResults := models.StepRunResultsModel{
StepName: name,
Status: resultCode,
Idx: buildRunResults.ResultsCount(),
RunTime: time.Now().Sub(stepStartTime),
Error: err,
ExitCode: exitCode,
}
switch resultCode {
case models.StepRunStatusCodeSuccess:
buildRunResults.SuccessSteps = append(buildRunResults.SuccessSteps, stepResults)
break
case models.StepRunStatusCodeFailed:
log.Errorf("Step (%s) failed, error: (%v)", name, err)
buildRunResults.FailedSteps = append(buildRunResults.FailedSteps, stepResults)
break
case models.StepRunStatusCodeFailedSkippable:
log.Warnf("Step (%s) failed, but was marked as skippable, error: (%v)", name, err)
buildRunResults.FailedSkippableSteps = append(buildRunResults.FailedSkippableSteps, stepResults)
break
case models.StepRunStatusCodeSkipped:
log.Warnf("A previous step failed, and this step (%s) was not marked as IsAlwaysRun, skipped", name)
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
case models.StepRunStatusCodeSkippedWithRunIf:
log.Warn("The step's (" + name + ") Run-If expression evaluated to false - skipping")
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
default:
log.Error("Unkown result code")
return
}
bitrise.PrintStepSummary(stepResults, isLastStep)
}
for idx, stepListItm := range workflow.Steps {
stepStartTime = time.Now()
isLastStep := isLastWorkflow && (idx == len(workflow.Steps)-1)
if err := bitrise.SetBuildFailedEnv(buildRunResults.IsBuildFailed()); err != nil {
log.Error("Failed to set Build Status envs")
}
//.........這裏部分代碼省略.........
示例10: PrintRunningWorkflow
// PrintRunningWorkflow ...
func PrintRunningWorkflow(title string) {
fmt.Println()
log.Infoln(colorstring.Blue("Switching to workflow:"), title)
fmt.Println()
}
示例11: triggerCheck
func triggerCheck(c *cli.Context) error {
warnings := []string{}
//
// Expand cli.Context
prGlobalFlag := c.GlobalBool(PRKey)
triggerPattern := c.String(PatternKey)
if triggerPattern == "" && len(c.Args()) > 0 {
triggerPattern = c.Args()[0]
}
pushBranch := c.String(PushBranchKey)
prSourceBranch := c.String(PRSourceBranchKey)
prTargetBranch := c.String(PRTargetBranchKey)
bitriseConfigBase64Data := c.String(ConfigBase64Key)
bitriseConfigPath := c.String(ConfigKey)
deprecatedBitriseConfigPath := c.String(PathKey)
if bitriseConfigPath == "" && deprecatedBitriseConfigPath != "" {
warnings = append(warnings, "'path' key is deprecated, use 'config' instead!")
bitriseConfigPath = deprecatedBitriseConfigPath
}
inventoryBase64Data := c.String(InventoryBase64Key)
inventoryPath := c.String(InventoryKey)
jsonParams := c.String(JSONParamsKey)
jsonParamsBase64 := c.String(JSONParamsBase64Key)
format := c.String(OuputFormatKey)
triggerParams, err := parseTriggerCheckParams(
triggerPattern,
pushBranch, prSourceBranch, prTargetBranch,
format,
bitriseConfigPath, bitriseConfigBase64Data,
inventoryPath, inventoryBase64Data,
jsonParams, jsonParamsBase64)
if err != nil {
registerFatal(fmt.Sprintf("Failed to parse trigger check params, err: %s", err), warnings, triggerParams.Format)
}
//
// Inventory validation
inventoryEnvironments, err := CreateInventoryFromCLIParams(triggerParams.InventoryBase64Data, triggerParams.InventoryPath)
if err != nil {
registerFatal(fmt.Sprintf("Failed to create inventory, err: %s", err), warnings, triggerParams.Format)
}
// Config validation
bitriseConfig, warns, err := CreateBitriseConfigFromCLIParams(triggerParams.BitriseConfigBase64Data, triggerParams.BitriseConfigPath)
warnings = append(warnings, warns...)
if err != nil {
registerFatal(fmt.Sprintf("Failed to create config, err: %s", err), warnings, triggerParams.Format)
}
// Format validation
if triggerParams.Format == "" {
triggerParams.Format = output.FormatRaw
} else if !(triggerParams.Format == output.FormatRaw || triggerParams.Format == output.FormatJSON) {
registerFatal(fmt.Sprintf("Invalid format: %s", triggerParams.Format), warnings, output.FormatJSON)
}
// Trigger filter validation
if triggerParams.TriggerPattern == "" &&
triggerParams.PushBranch == "" && triggerParams.PRSourceBranch == "" && triggerParams.PRTargetBranch == "" {
registerFatal("No trigger pattern nor trigger params specified", warnings, triggerParams.Format)
}
//
//
// Main
isPRMode, err := isPRMode(prGlobalFlag, inventoryEnvironments)
if err != nil {
registerFatal(fmt.Sprintf("Failed to check PR mode, err: %s", err), warnings, triggerParams.Format)
}
workflowToRunID, err := getWorkflowIDByParamsInCompatibleMode(bitriseConfig.TriggerMap, triggerParams, isPRMode)
if err != nil {
registerFatal(err.Error(), warnings, triggerParams.Format)
}
switch triggerParams.Format {
case output.FormatRaw:
fmt.Printf("%s -> %s\n", triggerParams.TriggerPattern, colorstring.Blue(workflowToRunID))
break
case output.FormatJSON:
triggerModel := map[string]string{
"pattern": triggerParams.TriggerPattern,
"workflow": workflowToRunID,
}
bytes, err := json.Marshal(triggerModel)
if err != nil {
registerFatal(fmt.Sprintf("Failed to parse trigger model, err: %s", err), warnings, triggerParams.Format)
}
fmt.Println(string(bytes))
break
default:
//.........這裏部分代碼省略.........
示例12: activateAndRunSteps
func activateAndRunSteps(workflow models.WorkflowModel, defaultStepLibSource string, buildRunResults models.BuildRunResultsModel, environments *[]envmanModels.EnvironmentItemModel, isLastWorkflow bool) models.BuildRunResultsModel {
log.Debugln("[BITRISE_CLI] - Activating and running steps")
// ------------------------------------------
// In function global variables - These are global for easy use in local register step run result methods.
var stepStartTime time.Time
// ------------------------------------------
// In function method - Registration methods, for register step run results.
registerStepRunResults := func(step stepmanModels.StepModel, stepInfoPtr stepmanModels.StepInfoModel,
stepIdxPtr int, runIf string, resultCode, exitCode int, err error, isLastStep, printStepHeader bool) {
if printStepHeader {
bitrise.PrintRunningStepHeader(stepInfoPtr, step, stepIdxPtr)
}
stepInfoCopy := stepmanModels.StepInfoModel{
ID: stepInfoPtr.ID,
Title: stepInfoPtr.Title,
Version: stepInfoPtr.Version,
Latest: stepInfoPtr.Latest,
SupportURL: stepInfoPtr.SupportURL,
SourceCodeURL: stepInfoPtr.SourceCodeURL,
GlobalInfo: stepInfoPtr.GlobalInfo,
}
stepResults := models.StepRunResultsModel{
StepInfo: stepInfoCopy,
Status: resultCode,
Idx: buildRunResults.ResultsCount(),
RunTime: time.Now().Sub(stepStartTime),
Error: err,
ExitCode: exitCode,
}
isExitStatusError := true
if err != nil {
isExitStatusError = errorutil.IsExitStatusError(err)
}
switch resultCode {
case models.StepRunStatusCodeSuccess:
buildRunResults.SuccessSteps = append(buildRunResults.SuccessSteps, stepResults)
break
case models.StepRunStatusCodeFailed:
if !isExitStatusError {
log.Errorf("Step (%s) failed, error: %s", stepInfoCopy.Title, err)
}
buildRunResults.FailedSteps = append(buildRunResults.FailedSteps, stepResults)
break
case models.StepRunStatusCodeFailedSkippable:
if !isExitStatusError {
log.Warnf("Step (%s) failed, but was marked as skippable, error: %s", stepInfoCopy.Title, err)
} else {
log.Warnf("Step (%s) failed, but was marked as skippable", stepInfoCopy.Title)
}
buildRunResults.FailedSkippableSteps = append(buildRunResults.FailedSkippableSteps, stepResults)
break
case models.StepRunStatusCodeSkipped:
log.Warnf("A previous step failed, and this step (%s) was not marked as IsAlwaysRun, skipped", stepInfoCopy.Title)
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
case models.StepRunStatusCodeSkippedWithRunIf:
log.Warn("The step's (" + stepInfoCopy.Title + ") Run-If expression evaluated to false - skipping")
if runIf != "" {
log.Info("The Run-If expression was: ", colorstring.Blue(runIf))
}
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
default:
log.Error("Unkown result code")
return
}
bitrise.PrintRunningStepFooter(stepResults, isLastStep)
}
// ------------------------------------------
// Main - Preparing & running the steps
for idx, stepListItm := range workflow.Steps {
// Per step variables
stepStartTime = time.Now()
isLastStep := isLastWorkflow && (idx == len(workflow.Steps)-1)
stepInfoPtr := stepmanModels.StepInfoModel{}
stepIdxPtr := idx
// Per step cleanup
if err := bitrise.SetBuildFailedEnv(buildRunResults.IsBuildFailed()); err != nil {
log.Error("Failed to set Build Status envs")
}
if err := bitrise.CleanupStepWorkDir(); err != nil {
registerStepRunResults(stepmanModels.StepModel{}, stepInfoPtr, stepIdxPtr,
"", models.StepRunStatusCodeFailed, 1, err, isLastStep, true)
continue
}
//.........這裏部分代碼省略.........
示例13: activateAndRunSteps
func activateAndRunSteps(workflow models.WorkflowModel, defaultStepLibSource string, buildRunResults models.BuildRunResultsModel, environments *[]envmanModels.EnvironmentItemModel, isLastWorkflow bool) models.BuildRunResultsModel {
log.Debugln("[BITRISE_CLI] - Activating and running steps")
// ------------------------------------------
// In function global variables - These are global for easy use in local register step run result methods.
var stepStartTime time.Time
// Holds pointer to current step info, for easy usage in local register step run result methods.
// The value is filled with the current running step info.
var stepInfoPtr models.StepInfoModel
// ------------------------------------------
// In function method - Registration methods, for register step run results.
registerStepRunResults := func(runIf string, resultCode, exitCode int, err error, isLastStep bool) {
stepInfoCopy := models.StepInfoModel{
ID: stepInfoPtr.ID,
Version: stepInfoPtr.Version,
Latest: stepInfoPtr.Latest,
}
stepResults := models.StepRunResultsModel{
StepInfo: stepInfoCopy,
Status: resultCode,
Idx: buildRunResults.ResultsCount(),
RunTime: time.Now().Sub(stepStartTime),
Error: err,
ExitCode: exitCode,
}
switch resultCode {
case models.StepRunStatusCodeSuccess:
buildRunResults.SuccessSteps = append(buildRunResults.SuccessSteps, stepResults)
break
case models.StepRunStatusCodeFailed:
log.Errorf("Step (%s) failed, error: (%v)", stepInfoCopy.ID, err)
buildRunResults.FailedSteps = append(buildRunResults.FailedSteps, stepResults)
break
case models.StepRunStatusCodeFailedSkippable:
log.Warnf("Step (%s) failed, but was marked as skippable, error: (%v)", stepInfoCopy.ID, err)
buildRunResults.FailedSkippableSteps = append(buildRunResults.FailedSkippableSteps, stepResults)
break
case models.StepRunStatusCodeSkipped:
log.Warnf("A previous step failed, and this step (%s) was not marked as IsAlwaysRun, skipped", stepInfoCopy.ID)
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
case models.StepRunStatusCodeSkippedWithRunIf:
log.Warn("The step's (" + stepInfoCopy.ID + ") Run-If expression evaluated to false - skipping")
if runIf != "" {
log.Info("The Run-If expression was: ", colorstring.Blue(runIf))
}
buildRunResults.SkippedSteps = append(buildRunResults.SkippedSteps, stepResults)
break
default:
log.Error("Unkown result code")
return
}
bitrise.PrintStepSummary(stepResults, isLastStep)
}
// ------------------------------------------
// Main - Preparing & running the steps
for idx, stepListItm := range workflow.Steps {
// Per step variables
stepStartTime = time.Now()
isLastStep := isLastWorkflow && (idx == len(workflow.Steps)-1)
stepInfoPtr = models.StepInfoModel{}
// Per step cleanup
if err := bitrise.SetBuildFailedEnv(buildRunResults.IsBuildFailed()); err != nil {
log.Error("Failed to set Build Status envs")
}
if err := bitrise.CleanupStepWorkDir(); err != nil {
registerStepRunResults("", models.StepRunStatusCodeFailed, 1, err, isLastStep)
continue
}
//
// Preparing the step
// Get step id & version data
compositeStepIDStr, workflowStep, err := models.GetStepIDStepDataPair(stepListItm)
stepInfoPtr.ID = compositeStepIDStr
if workflowStep.Title != nil && *workflowStep.Title != "" {
stepInfoPtr.ID = *workflowStep.Title
}
if err != nil {
registerStepRunResults("", models.StepRunStatusCodeFailed, 1, err, isLastStep)
continue
}
stepIDData, err := models.CreateStepIDDataFromString(compositeStepIDStr, defaultStepLibSource)
stepInfoPtr.ID = stepIDData.IDorURI
if workflowStep.Title != nil && *workflowStep.Title != "" {
stepInfoPtr.ID = *workflowStep.Title
}
stepInfoPtr.Version = stepIDData.Version
if err != nil {
registerStepRunResults("", models.StepRunStatusCodeFailed, 1, err, isLastStep)
//.........這裏部分代碼省略.........
示例14: collectAndExportProvisioningProfiles
func collectAndExportProvisioningProfiles(codeSigningSettings common.CodeSigningSettings,
absExportOutputDirPath string) (provprofile.ProvisioningProfileFileInfoModels, error) {
provProfileFileInfos := []provprofile.ProvisioningProfileFileInfoModel{}
fmt.Println()
log.Println(colorstring.Green("Searching for required Provisioning Profiles"), "...")
fmt.Println()
provProfileUUIDLookupMap := map[string]provprofile.ProvisioningProfileFileInfoModel{}
for _, aProvProfile := range codeSigningSettings.ProvProfiles {
log.Infof(" * "+colorstring.Blue("Searching for required Provisioning Profile")+": %s (UUID: %s)", aProvProfile.Title, aProvProfile.UUID)
provProfileFileInfo, err := provprofile.FindProvProfileByUUID(aProvProfile.UUID)
if err != nil {
return provProfileFileInfos, fmt.Errorf("Failed to find Provisioning Profile: %s", err)
}
log.Infof(" File found at: %s", provProfileFileInfo.Path)
provProfileUUIDLookupMap[provProfileFileInfo.ProvisioningProfileInfo.UUID] = provProfileFileInfo
}
fmt.Println()
log.Println(colorstring.Green("Searching for additinal, Distribution Provisioning Profiles"), "...")
fmt.Println()
for _, aAppBundleID := range codeSigningSettings.AppIDs {
bundleOrAppIDPattern := common.BundleIDFromAppID(aAppBundleID)
if bundleOrAppIDPattern == "" {
// no bundle ID found in the app id
bundleOrAppIDPattern = aAppBundleID
} else {
// bundle ID found, make it a glob pattern
bundleOrAppIDPattern = "*." + bundleOrAppIDPattern
}
log.Infof(" * "+colorstring.Blue("Searching for Provisioning Profiles with App ID pattern")+": %s", bundleOrAppIDPattern)
provProfileFileInfos, err := provprofile.FindProvProfilesByAppID(bundleOrAppIDPattern)
if err != nil {
return provProfileFileInfos, fmt.Errorf("Error during Provisioning Profile search: %s", err)
}
if len(provProfileFileInfos) < 1 {
log.Warn(" No Provisioning Profile found for this Bundle ID")
continue
}
log.Infof(" Found matching Provisioning Profile count: %d", len(provProfileFileInfos))
for _, aProvProfileFileInfo := range provProfileFileInfos {
provProfileUUIDLookupMap[aProvProfileFileInfo.ProvisioningProfileInfo.UUID] = aProvProfileFileInfo
}
}
fmt.Println()
log.Println(colorstring.Green("Exporting Provisioning Profiles"), "...")
fmt.Println()
for _, aProvProfFileInfo := range provProfileUUIDLookupMap {
provProfileFileInfos = append(provProfileFileInfos, aProvProfFileInfo)
}
if err := exportProvisioningProfiles(provProfileFileInfos, absExportOutputDirPath); err != nil {
return provProfileFileInfos, fmt.Errorf("Failed to export the Provisioning Profile into the export directory: %s", err)
}
return provProfileFileInfos, nil
}
示例15: share
func share(c *cli.Context) error {
toolMode := c.Bool(ToolMode)
guide := `
Do you want to ` + colorstring.Green("share ") + colorstring.Yellow("your ") + colorstring.Magenta("own ") + colorstring.Blue("Step") + ` with the world? Awesome!!
To get started you can find a template Step repository at: ` + colorstring.Green("https://github.com/bitrise-steplib/step-template") + `
Once you have your Step in a ` + colorstring.Yellow("public git repository") + ` you can share it with others.
To share your Step just follow these steps (pun intended ;) :
1. ` + GuideTextForStart() + `
2. ` + GuideTextForShareStart(toolMode) + `
3. ` + GuideTextForShareCreate(toolMode) + `
4. ` + GuideTextForAudit(toolMode) + `
5. ` + GuideTextForShareFinish(toolMode) + `
6. ` + GuideTextForFinish()
fmt.Println(guide)
return nil
}