-
Notifications
You must be signed in to change notification settings - Fork 0
/
jobmanager.go
36 lines (33 loc) · 1.56 KB
/
jobmanager.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/*
* Copyright (c) 2017-2018 Samsung Electronics Co., Ltd All Rights Reserved
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License
*/
// File jobmanager.go provides JobManager interface.
package weles
// JobManager interface defines API for actions that can be called on Weles' Jobs
// by external modules. These methods are intended to be used by HTTP server.
type JobManager interface {
// CreateJob creates a new Job in Weles using recipe passed in YAML format.
// It returns ID of created Job or error.
CreateJob(yaml []byte) (JobID, error)
// CancelJob stops execution of Job identified by JobID.
CancelJob(JobID) error
// ListJobs returns information on Jobs. It takes 3 arguments:
// - JobFilter containing filters
// - JobSorter containing sorting key and sorting direction
// - JobPagination containing element after/before which a page should be returned. It also
// contains information about direction of listing and the size of the returned page which
// must always be set.
ListJobs(JobFilter, JobSorter, JobPagination) ([]JobInfo, ListInfo, error)
}