Documentation ¶
Index ¶
- Constants
- type Address
- type Color
- type ColorService
- type ControllerParams
- type DataSourceService
- type Entity
- type Environment
- type EventData
- type EventFn
- type EventService
- type Export
- type ExportService
- type ExtraValue
- type Filter
- type FilterCondition
- type FsFileInfo
- type FsService
- type FsServiceV2
- type Git
- type GrpcBase
- type GrpcBaseServiceParams
- type GrpcClient
- type GrpcClientModelBaseService
- type GrpcClientModelDelegate
- type GrpcClientModelEnvironmentService
- type GrpcClientModelNodeService
- type GrpcClientModelService
- type GrpcClientModelSpiderService
- type GrpcClientModelTaskService
- type GrpcClientModelTaskStatService
- type GrpcClientPool
- type GrpcModelBaseServiceMessage
- type GrpcModelBinder
- type GrpcModelDelegateMessage
- type GrpcModelListBinder
- type GrpcServer
- type GrpcStream
- type GrpcStreamBidirectional
- type GrpcSubscribe
- type I18nService
- type Injectable
- type List
- type Model
- type ModelArtifact
- type ModelArtifactSys
- type ModelBaseService
- type ModelBinder
- type ModelDelegate
- type ModelDelegateMethod
- type ModelId
- type ModelListBinder
- type ModelNodeDelegate
- type ModelService
- type ModelServiceV2
- type ModelV2
- type ModelWithKey
- type ModelWithNameDescription
- type ModelWithTags
- type Module
- type ModuleId
- type Node
- type NodeConfigService
- type NodeMasterService
- type NodeService
- type NodeServiceOption
- type NodeWorkerService
- type Permission
- type ProcessDaemon
- type Provide
- type Result
- type ResultService
- type ResultServiceMongo
- type ResultServiceRegistry
- type ResultServiceRegistryFn
- type Role
- type Schedule
- type ScheduleService
- type ServiceCrudOption
- type ServiceCrudOptions
- type Spider
- type SpiderAdminService
- type SpiderCloneOptions
- type SpiderRunOptions
- type StatsService
- type Tag
- type Task
- type TaskBaseService
- type TaskHandlerService
- type TaskHookService
- type TaskRunner
- type TaskSchedulerService
- type TaskStat
- type TaskStatsService
- type Test
- type Translation
- type User
- type UserCreateOptions
- type UserGroup
- type UserLoginOptions
- type UserService
- type WithAddress
- type WithConfigPath
- type WithModelId
Constants ¶
View Source
const ( ModelIdArtifact = iota ModelIdTag ModelIdNode ModelIdProject ModelIdSpider ModelIdTask ModelIdJob ModelIdSchedule ModelIdUser ModelIdSetting ModelIdToken ModelIdVariable ModelIdTaskQueue ModelIdTaskStat ModelIdSpiderStat ModelIdDataSource ModelIdDataCollection ModelIdResult ModelIdPassword ModelIdExtraValue ModelIdGit ModelIdRole ModelIdUserRole ModelIdPermission ModelIdRolePermission ModelIdEnvironment ModelIdDependencySetting )
View Source
const ( ModelColNameArtifact = "artifacts" ModelColNameTag = "tags" ModelColNameNode = "nodes" ModelColNameProject = "projects" ModelColNameSpider = "spiders" ModelColNameTask = "tasks" ModelColNameJob = "jobs" ModelColNameSchedule = "schedules" ModelColNameUser = "users" ModelColNameSetting = "settings" ModelColNameToken = "tokens" ModelColNameVariable = "variables" ModelColNameTaskQueue = "task_queue" ModelColNameTaskStat = "task_stats" ModelColNameSpiderStat = "spider_stats" ModelColNameDataSource = "data_sources" ModelColNameDataCollection = "data_collections" ModelColNamePasswords = "passwords" ModelColNameExtraValues = "extra_values" ModelColNameGit = "gits" ModelColNameRole = "roles" ModelColNameUserRole = "user_roles" ModelColNamePermission = "permissions" ModelColNameRolePermission = "role_permissions" ModelColNameEnvironment = "environments" ModelColNameDependencySetting = "dependency_settings" )
View Source
const ( ModelDelegateMethodAdd = "add" ModelDelegateMethodSave = "save" ModelDelegateMethodDelete = "delete" ModelDelegateMethodGetArtifact = "get-artifact" ModelDelegateMethodRefresh = "refresh" ModelDelegateMethodChange = "change" )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ColorService ¶
type ControllerParams ¶
type DataSourceService ¶
type Environment ¶
type EventService ¶
type ExportService ¶
type ExtraValue ¶
type Filter ¶
type Filter interface { GetIsOr() (isOr bool) SetIsOr(isOr bool) GetConditions() (conditions []FilterCondition) SetConditions(conditions []FilterCondition) IsNil() (ok bool) }
type FilterCondition ¶
type FsFileInfo ¶
type FsService ¶
type FsService interface { WithConfigPath List(path string, opts ...ServiceCrudOption) (files []FsFileInfo, err error) GetFile(path string, opts ...ServiceCrudOption) (data []byte, err error) GetFileInfo(path string, opts ...ServiceCrudOption) (file FsFileInfo, err error) Save(path string, data []byte, opts ...ServiceCrudOption) (err error) Rename(path, newPath string, opts ...ServiceCrudOption) (err error) Delete(path string, opts ...ServiceCrudOption) (err error) Copy(path, newPath string, opts ...ServiceCrudOption) (err error) Commit(msg string) (err error) SyncToFs(opts ...ServiceCrudOption) (err error) SyncToWorkspace() (err error) GetFsPath() (path string) SetFsPath(path string) GetWorkspacePath() (path string) SetWorkspacePath(path string) GetRepoPath() (path string) SetRepoPath(path string) GetFs() (fs cfs.Manager) GetGitClient() (c *vcs.GitClient) }
type FsServiceV2 ¶
type FsServiceV2 interface { List(path string) (files []FsFileInfo, err error) GetFile(path string) (data []byte, err error) GetFileInfo(path string) (file FsFileInfo, err error) Save(path string, data []byte) (err error) CreateDir(path string) (err error) Rename(path, newPath string) (err error) Delete(path string) (err error) Copy(path, newPath string) (err error) Export() (resultPath string, err error) }
type Git ¶
type Git interface { Model GetUrl() (url string) SetUrl(url string) GetAuthType() (authType string) SetAuthType(authType string) GetUsername() (username string) SetUsername(username string) GetPassword() (password string) SetPassword(password string) GetCurrentBranch() (currentBranch string) SetCurrentBranch(currentBranch string) GetAutoPull() (autoPull bool) SetAutoPull(autoPull bool) }
Git interface
type GrpcBase ¶
type GrpcBase interface { WithConfigPath Init() (err error) Start() (err error) Stop() (err error) Register() (err error) }
type GrpcBaseServiceParams ¶
type GrpcBaseServiceParams interface { Entity }
type GrpcClient ¶
type GrpcClient interface { GrpcBase WithConfigPath GetModelDelegateClient() grpc.ModelDelegateClient GetModelBaseServiceClient() grpc.ModelBaseServiceClient GetNodeClient() grpc.NodeServiceClient GetTaskClient() grpc.TaskServiceClient GetMessageClient() grpc.MessageServiceClient SetAddress(Address) SetTimeout(time.Duration) SetSubscribeType(string) SetHandleMessage(bool) Context() (context.Context, context.CancelFunc) NewRequest(interface{}) *grpc.Request GetMessageChannel() chan *grpc.StreamMessage Restart() error NewModelBaseServiceRequest(ModelId, GrpcBaseServiceParams) (*grpc.Request, error) IsStarted() bool IsClosed() bool Err() error GetStream() grpc.NodeService_SubscribeClient }
type GrpcClientModelBaseService ¶
type GrpcClientModelBaseService interface { WithModelId WithConfigPath ModelBaseService }
type GrpcClientModelDelegate ¶
type GrpcClientModelDelegate interface { ModelDelegate WithConfigPath Close() error }
type GrpcClientModelEnvironmentService ¶
type GrpcClientModelEnvironmentService interface { ModelBaseService GetEnvironmentById(id primitive.ObjectID) (s Environment, err error) GetEnvironment(query bson.M, opts *mongo.FindOptions) (s Environment, err error) GetEnvironmentList(query bson.M, opts *mongo.FindOptions) (res []Environment, err error) }
type GrpcClientModelNodeService ¶
type GrpcClientModelNodeService interface { ModelBaseService GetNodeById(id primitive.ObjectID) (n Node, err error) GetNode(query bson.M, opts *mongo.FindOptions) (n Node, err error) GetNodeByKey(key string) (n Node, err error) GetNodeList(query bson.M, opts *mongo.FindOptions) (res []Node, err error) }
type GrpcClientModelService ¶
type GrpcClientModelService interface { WithConfigPath NewBaseServiceDelegate(id ModelId) (GrpcClientModelBaseService, error) }
type GrpcClientPool ¶
type GrpcClientPool interface { WithConfigPath Init() error NewClient() error GetClient() (GrpcClient, error) SetSize(int) }
type GrpcModelBinder ¶
type GrpcModelBinder interface { ModelBinder }
type GrpcModelDelegateMessage ¶
type GrpcModelDelegateMessage interface { GetModelId() ModelId GetMethod() ModelDelegateMethod GetData() []byte ToBytes() (data []byte) }
type GrpcModelListBinder ¶
type GrpcModelListBinder interface { ModelListBinder }
type GrpcServer ¶
type GrpcServer interface { GrpcBase SetAddress(Address) GetSubscribe(key string) (sub GrpcSubscribe, err error) SetSubscribe(key string, sub GrpcSubscribe) DeleteSubscribe(key string) SendStreamMessage(key string, code grpc.StreamMessageCode) (err error) SendStreamMessageWithData(nodeKey string, code grpc.StreamMessageCode, d interface{}) (err error) IsStopped() (res bool) }
type GrpcStream ¶
type GrpcStream interface {
Send(msg *grpc.StreamMessage) (err error)
}
type GrpcStreamBidirectional ¶
type GrpcStreamBidirectional interface { GrpcStream Recv() (msg *grpc.StreamMessage, err error) }
type GrpcSubscribe ¶
type GrpcSubscribe interface { GetStream() GrpcStream GetStreamBidirectional() GrpcStreamBidirectional GetFinished() chan bool }
type I18nService ¶
type I18nService interface { AddTranslations(t []Translation) GetTranslations() (t []Translation) }
type Injectable ¶
type Injectable interface {
Inject() error
}
type ModelArtifact ¶
type ModelArtifactSys ¶
type ModelArtifactSys interface { GetCreateTs() time.Time SetCreateTs(ts time.Time) GetUpdateTs() time.Time SetUpdateTs(ts time.Time) GetDeleteTs() time.Time SetDeleteTs(ts time.Time) GetCreateUid() primitive.ObjectID SetCreateUid(id primitive.ObjectID) GetUpdateUid() primitive.ObjectID SetUpdateUid(id primitive.ObjectID) GetDeleteUid() primitive.ObjectID SetDeleteUid(id primitive.ObjectID) }
type ModelBaseService ¶
type ModelBaseService interface { GetModelId() (id ModelId) SetModelId(id ModelId) GetById(id primitive.ObjectID) (res Model, err error) Get(query bson.M, opts *mongo.FindOptions) (res Model, err error) GetList(query bson.M, opts *mongo.FindOptions) (res List, err error) DeleteById(id primitive.ObjectID, args ...interface{}) (err error) Delete(query bson.M, args ...interface{}) (err error) DeleteList(query bson.M, args ...interface{}) (err error) ForceDeleteList(query bson.M, args ...interface{}) (err error) UpdateById(id primitive.ObjectID, update bson.M, args ...interface{}) (err error) Update(query bson.M, update bson.M, fields []string, args ...interface{}) (err error) UpdateDoc(query bson.M, doc Model, fields []string, args ...interface{}) (err error) Insert(u User, docs ...interface{}) (err error) Count(query bson.M) (total int, err error) }
type ModelBinder ¶
type ModelDelegate ¶
type ModelDelegateMethod ¶
type ModelDelegateMethod string
type ModelListBinder ¶
type ModelNodeDelegate ¶
type ModelService ¶
type ModelService interface {
GetBaseService(id ModelId) (svc ModelBaseService)
}
type ModelServiceV2 ¶
type ModelServiceV2[T any] interface { GetById(id primitive.ObjectID) (model *T, err error) Get(query bson.M, options *mongo.FindOptions) (model *T, err error) GetList(query bson.M, options *mongo.FindOptions) (models []T, err error) DeleteById(id primitive.ObjectID) (err error) Delete(query bson.M) (err error) DeleteList(query bson.M) (err error) UpdateById(id primitive.ObjectID, update bson.M) (err error) UpdateOne(query bson.M, update bson.M) (err error) UpdateMany(query bson.M, update bson.M) (err error) ReplaceById(id primitive.ObjectID, model T) (err error) Replace(query bson.M, model T) (err error) InsertOne(model T) (id primitive.ObjectID, err error) InsertMany(models []T) (ids []primitive.ObjectID, err error) Count(query bson.M) (total int, err error) GetCol() (col *mongo.Col) }
type ModelWithKey ¶
type ModelWithTags ¶
type Node ¶
type Node interface { ModelWithNameDescription GetKey() (key string) GetIsMaster() (ok bool) GetActive() (active bool) SetActive(active bool) SetActiveTs(activeTs time.Time) GetStatus() (status string) SetStatus(status string) GetEnabled() (enabled bool) SetEnabled(enabled bool) GetAvailableRunners() (runners int) SetAvailableRunners(runners int) GetMaxRunners() (runners int) SetMaxRunners(runners int) IncrementAvailableRunners() DecrementAvailableRunners() }
type NodeConfigService ¶
type NodeMasterService ¶
type NodeMasterService interface { NodeService Monitor() SetMonitorInterval(duration time.Duration) Register() error StopOnError() GetServer() GrpcServer }
type NodeService ¶
type NodeService interface { Module WithConfigPath WithAddress GetConfigService() NodeConfigService }
type NodeServiceOption ¶
type NodeServiceOption interface { }
type NodeWorkerService ¶
type NodeWorkerService interface { NodeService Register() Recv() ReportStatus() SetHeartbeatInterval(duration time.Duration) }
type Permission ¶
type Permission interface { ModelWithKey ModelWithNameDescription GetType() (t string) SetType(t string) GetTarget() (target []string) SetTarget(target []string) GetAllow() (allow []string) SetAllow(allow []string) GetDeny() (deny []string) SetDeny(deny []string) }
type ProcessDaemon ¶
type ResultService ¶
type ResultServiceMongo ¶
type ResultServiceRegistry ¶
type ResultServiceRegistry interface { Register(key string, fn ResultServiceRegistryFn) Unregister(key string) Get(key string) (fn ResultServiceRegistryFn) }
type ResultServiceRegistryFn ¶
type Role ¶
type Role interface { ModelWithKey ModelWithNameDescription }
type Schedule ¶
type Schedule interface { Model GetEnabled() (enabled bool) SetEnabled(enabled bool) GetEntryId() (id cron.EntryID) SetEntryId(id cron.EntryID) GetCron() (c string) SetCron(c string) GetSpiderId() (id primitive.ObjectID) SetSpiderId(id primitive.ObjectID) GetMode() (mode string) SetMode(mode string) GetNodeIds() (ids []primitive.ObjectID) SetNodeIds(ids []primitive.ObjectID) GetCmd() (cmd string) SetCmd(cmd string) GetParam() (param string) SetParam(param string) GetPriority() (p int) SetPriority(p int) }
type ScheduleService ¶
type ScheduleService interface { WithConfigPath Module GetLocation() (loc *time.Location) SetLocation(loc *time.Location) GetDelay() (delay bool) SetDelay(delay bool) GetSkip() (skip bool) SetSkip(skip bool) GetUpdateInterval() (interval time.Duration) SetUpdateInterval(interval time.Duration) Enable(s Schedule, args ...interface{}) (err error) Disable(s Schedule, args ...interface{}) (err error) Update() GetCron() (c *cron.Cron) }
type ServiceCrudOption ¶
type ServiceCrudOption func(o *ServiceCrudOptions)
func WithNotSyncToWorkspace ¶
func WithNotSyncToWorkspace() ServiceCrudOption
func WithOnlyFromWorkspace ¶
func WithOnlyFromWorkspace() ServiceCrudOption
type ServiceCrudOptions ¶
type Spider ¶
type Spider interface { ModelWithNameDescription GetType() (ty string) GetMode() (mode string) SetMode(mode string) GetNodeIds() (ids []primitive.ObjectID) SetNodeIds(ids []primitive.ObjectID) GetCmd() (cmd string) SetCmd(cmd string) GetParam() (param string) SetParam(param string) GetPriority() (p int) SetPriority(p int) GetColId() (id primitive.ObjectID) SetColId(id primitive.ObjectID) GetIncrementalSync() (incrementalSync bool) SetIncrementalSync(incrementalSync bool) GetAutoInstall() (autoInstall bool) SetAutoInstall(autoInstall bool) }
type SpiderAdminService ¶
type SpiderAdminService interface { WithConfigPath Start() (err error) // Schedule a new task of the spider Schedule(id primitive.ObjectID, opts *SpiderRunOptions) (taskIds []primitive.ObjectID, err error) // Clone the spider Clone(id primitive.ObjectID, opts *SpiderCloneOptions) (err error) // Delete the spider Delete(id primitive.ObjectID) (err error) // SyncGit syncs all git repositories SyncGit() (err error) // SyncGitOne syncs one git repository SyncGitOne(g Git) (err error) // Export exports the spider and return zip file path Export(id primitive.ObjectID) (filePath string, err error) }
type SpiderCloneOptions ¶
type SpiderCloneOptions struct {
Name string
}
type SpiderRunOptions ¶
type StatsService ¶
type Task ¶
type Task interface { Model GetNodeId() (id primitive.ObjectID) SetNodeId(id primitive.ObjectID) GetNodeIds() (ids []primitive.ObjectID) GetStatus() (status string) SetStatus(status string) GetError() (error string) SetError(error string) GetPid() (pid int) SetPid(pid int) GetSpiderId() (id primitive.ObjectID) GetType() (ty string) GetCmd() (cmd string) GetParam() (param string) GetPriority() (p int) GetUserId() (id primitive.ObjectID) SetUserId(id primitive.ObjectID) }
type TaskBaseService ¶
type TaskHandlerService ¶
type TaskHandlerService interface { TaskBaseService // Run task and execute locally Run(taskId primitive.ObjectID) (err error) // Cancel task locally Cancel(taskId primitive.ObjectID) (err error) // Fetch tasks and run Fetch() // ReportStatus periodically report handler status to master ReportStatus() // Reset reset internals to default Reset() // IsSyncLocked whether the given task is locked for files sync IsSyncLocked(path string) (ok bool) // LockSync lock files sync for given task LockSync(path string) // UnlockSync unlock files sync for given task UnlockSync(path string) // GetExitWatchDuration get max runners GetExitWatchDuration() (duration time.Duration) // SetExitWatchDuration set max runners SetExitWatchDuration(duration time.Duration) // GetFetchInterval get report interval GetFetchInterval() (interval time.Duration) // SetFetchInterval set report interval SetFetchInterval(interval time.Duration) // GetReportInterval get report interval GetReportInterval() (interval time.Duration) // SetReportInterval set report interval SetReportInterval(interval time.Duration) // GetCancelTimeout get report interval GetCancelTimeout() (timeout time.Duration) // SetCancelTimeout set report interval SetCancelTimeout(timeout time.Duration) // GetModelService get model service GetModelService() (modelSvc GrpcClientModelService) // GetModelSpiderService get model spider service GetModelSpiderService() (modelSpiderSvc GrpcClientModelSpiderService) // GetModelTaskService get model task service GetModelTaskService() (modelTaskSvc GrpcClientModelTaskService) // GetModelTaskStatService get model task stat service GetModelTaskStatService() (modelTaskStatSvc GrpcClientModelTaskStatService) // GetModelEnvironmentService get model environment service GetModelEnvironmentService() (modelEnvironmentSvc GrpcClientModelEnvironmentService) // GetNodeConfigService get node config service GetNodeConfigService() (cfgSvc NodeConfigService) // GetCurrentNode get node of the handler GetCurrentNode() (n Node, err error) // GetTaskById get task by id GetTaskById(id primitive.ObjectID) (t Task, err error) // GetSpiderById get task by id GetSpiderById(id primitive.ObjectID) (t Spider, err error) }
type TaskHookService ¶
type TaskHookService interface { PreActions(Task, Spider, FsServiceV2, TaskHandlerService) (err error) PostActions(Task, Spider, FsServiceV2, TaskHandlerService) (err error) }
type TaskRunner ¶
type TaskSchedulerService ¶
type TaskSchedulerService interface { TaskBaseService // Enqueue task into the task queue Enqueue(t Task) (t2 Task, err error) // Cancel task to corresponding node Cancel(id primitive.ObjectID, args ...interface{}) (err error) // SetInterval set the interval or duration between two adjacent fetches SetInterval(interval time.Duration) }
type TaskStat ¶
type TaskStat interface { Model GetCreateTs() (ts time.Time) SetCreateTs(ts time.Time) GetStartTs() (ts time.Time) SetStartTs(ts time.Time) GetEndTs() (ts time.Time) SetEndTs(ts time.Time) GetWaitDuration() (d int64) SetWaitDuration(d int64) GetRuntimeDuration() (d int64) SetRuntimeDuration(d int64) GetTotalDuration() (d int64) SetTotalDuration(d int64) GetResultCount() (c int64) SetResultCount(c int64) GetErrorLogCount() (c int64) SetErrorLogCount(c int64) }
type TaskStatsService ¶
type Translation ¶
type Translation interface {
GetLang() (l string)
}
type UserCreateOptions ¶
type UserLoginOptions ¶
type UserService ¶
type UserService interface { Init() (err error) SetJwtSecret(secret string) SetJwtSigningMethod(method jwt.SigningMethod) Create(opts *UserCreateOptions, args ...interface{}) (err error) Login(opts *UserLoginOptions) (token string, u User, err error) CheckToken(token string) (u User, err error) ChangePassword(id primitive.ObjectID, password string, args ...interface{}) (err error) MakeToken(user User) (tokenStr string, err error) GetCurrentUser(c *gin.Context) (u User, err error) }
type WithAddress ¶
type WithConfigPath ¶
type WithModelId ¶
Source Files ¶
- address.go
- color.go
- color_service.go
- controller_params.go
- data_source_service.go
- entity.go
- event_data.go
- event_service.go
- export.go
- export_service.go
- filter.go
- filter_condition.go
- fs_file_info.go
- fs_service.go
- fs_service_options.go
- fs_service_v2.go
- grpc_base.go
- grpc_base_service_params.go
- grpc_client.go
- grpc_client_model_base_service.go
- grpc_client_model_delegate.go
- grpc_client_model_environment_service.go
- grpc_client_model_node_service.go
- grpc_client_model_service.go
- grpc_client_model_spider_service.go
- grpc_client_model_task_service.go
- grpc_client_model_task_stat_service.go
- grpc_client_pool.go
- grpc_model_base_service_message.go
- grpc_model_binder.go
- grpc_model_delegate_message.go
- grpc_model_list_binder.go
- grpc_server.go
- grpc_stream.go
- grpc_subscribe.go
- i18n_service.go
- injectable.go
- list.go
- model.go
- model_artifact.go
- model_artifact_sys.go
- model_base_service.go
- model_binder.go
- model_delegate.go
- model_environment.go
- model_extra_value.go
- model_git.go
- model_list_binder.go
- model_node.go
- model_node_delegate.go
- model_permission.go
- model_result.go
- model_role.go
- model_schedule.go
- model_service_v2.go
- model_spider.go
- model_tag.go
- model_task.go
- model_task_stat.go
- model_user.go
- model_user_group.go
- module.go
- node_config_service.go
- node_master_service.go
- node_service.go
- node_service_option.go
- node_worker_service.go
- options.go
- process_daemon.go
- provide.go
- result_service.go
- result_service_mongo.go
- result_service_registry.go
- schedule_service.go
- spider_admin_service.go
- spider_service_options.go
- stats_service.go
- task_base_service.go
- task_handler_service.go
- task_hook_service.go
- task_runner.go
- task_scheduler_service.go
- task_stats_service.go
- test.go
- translation.go
- user_service.go
- user_service_options.go
- with_address.go
- with_config_path.go
- with_model_id.go
Click to show internal directories.
Click to hide internal directories.