func NewProvider( platform boshplatform.Platform, client boshmonit.Client, logger boshlog.Logger, dirProvider boshdir.DirectoriesProvider, handler boshhandler.Handler, ) (p provider) { monitJobSupervisor := NewMonitJobSupervisor( platform.GetFs(), platform.GetRunner(), client, logger, dirProvider, 2825, MonitReloadOptions{ MaxTries: 3, MaxCheckTries: 6, DelayBetweenCheckTries: 5 * time.Second, }, ) p.supervisors = map[string]JobSupervisor{ "monit": monitJobSupervisor, "dummy": newDummyJobSupervisor(), "dummy-nats": NewDummyNatsJobSupervisor(handler), } return }
func NewFactory( settingsService boshsettings.Service, platform boshplatform.Platform, blobstore boshblob.Blobstore, taskService boshtask.Service, notifier boshnotif.Notifier, applier boshappl.Applier, compiler boshcomp.Compiler, jobSupervisor boshjobsuper.JobSupervisor, specService boshas.V1Service, drainScriptProvider boshdrain.DrainScriptProvider, logger boshlog.Logger, ) (factory Factory) { compressor := platform.GetCompressor() copier := platform.GetCopier() dirProvider := platform.GetDirProvider() vitalsService := platform.GetVitalsService() ntpService := boshntp.NewConcreteService(platform.GetFs(), dirProvider) factory = concreteFactory{ availableActions: map[string]Action{ // Task management "ping": NewPing(), "get_task": NewGetTask(taskService), "cancel_task": NewCancelTask(taskService), // VM admin "ssh": NewSSH(settingsService, platform, dirProvider), "fetch_logs": NewFetchLogs(compressor, copier, blobstore, dirProvider), // Job management "prepare": NewPrepare(applier), "apply": NewApply(applier, specService, settingsService), "start": NewStart(jobSupervisor), "stop": NewStop(jobSupervisor), "drain": NewDrain(notifier, specService, drainScriptProvider, jobSupervisor), "get_state": NewGetState(settingsService, specService, jobSupervisor, vitalsService, ntpService), "run_errand": NewRunErrand(specService, dirProvider.JobsDir(), platform.GetRunner(), logger), // Compilation "compile_package": NewCompilePackage(compiler), "release_apply_spec": NewReleaseApplySpec(platform), // Disk management "list_disk": NewListDisk(settingsService, platform, logger), "migrate_disk": NewMigrateDisk(platform, dirProvider), "mount_disk": NewMountDisk(settingsService, platform, platform, dirProvider), "unmount_disk": NewUnmountDisk(settingsService, platform), // Networking "prepare_network_change": NewPrepareNetworkChange(platform.GetFs(), settingsService), "prepare_configure_networks": NewPrepareConfigureNetworks(platform, settingsService), "configure_networks": NewConfigureNetworks(), }, } return }
func NewProvider(platform boshplatform.Platform) (p provider) { fs := platform.GetFs() runner := platform.GetRunner() uuidGen := boshuuid.NewGenerator() p.blobstores = map[boshsettings.BlobstoreType]Blobstore{ boshsettings.BlobstoreTypeS3: newS3Blobstore(fs, runner, uuidGen), boshsettings.BlobstoreTypeDummy: newDummyBlobstore(), } return }
func NewProvider(platform boshplatform.Platform) (p provider) { fs := platform.GetFs() runner := platform.GetRunner() uuidGen := boshuuid.NewGenerator() s3cliConfigPath := filepath.Join(boshsettings.VCAP_ETC_DIR, "s3cli") p.blobstores = map[boshsettings.BlobstoreType]Blobstore{ boshsettings.BlobstoreTypeDav: newDummyBlobstore(), boshsettings.BlobstoreTypeDummy: newDummyBlobstore(), boshsettings.BlobstoreTypeS3: newS3Blobstore(fs, runner, uuidGen, s3cliConfigPath), } return }
func NewProvider( platform boshplatform.Platform, client boshmonit.Client, logger boshlog.Logger, dirProvider boshdir.DirectoriesProvider, ) (p provider) { p.supervisors = map[string]JobSupervisor{ "monit": NewMonitJobSupervisor(platform.GetFs(), platform.GetRunner(), client, logger, dirProvider), "dummy": newDummyJobSupervisor(), } return }
func NewProvider( platform boshplatform.Platform, client boshmonit.Client, logger boshlog.Logger, dirProvider boshdir.DirectoriesProvider, handler boshhandler.Handler, ) (p provider) { p.supervisors = map[string]JobSupervisor{ "monit": NewMonitJobSupervisor(platform.GetFs(), platform.GetRunner(), client, logger, dirProvider, 2825, 5*time.Second), "dummy": newDummyJobSupervisor(), "dummy-nats": NewDummyNatsJobSupervisor(handler), } return }