-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'mindsdb:main' into project-delete
- Loading branch information
Showing
18 changed files
with
774 additions
and
73 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
name: "MindsDB CLA Assistant" | ||
on: | ||
issue_comment: | ||
types: [created] | ||
pull_request_target: | ||
types: [opened,closed,synchronize] | ||
jobs: | ||
CLAssistant: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: "CLA Assistant" | ||
if: (github.event.comment.body == 'recheck' || github.event.comment.body == 'I have read the CLA Document and I hereby sign the CLA') || github.event_name == 'pull_request_target' | ||
uses: contributor-assistant/[email protected] | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.CLA_TOKEN }} | ||
PERSONAL_ACCESS_TOKEN : ${{ secrets.CLA_TOKEN }} | ||
with: | ||
path-to-signatures: 'assets/contributions-agreement/cla.json' | ||
# Add path to the CLA here | ||
path-to-document: 'https://github.com/mindsdb/mindsdb/blob/main/assets/contributions-agreement/individual-contributor.md' | ||
branch: 'cla' | ||
allowlist: bot*, ZoranPandovski, torrmal, Stpmax, mindsdbadmin, ea-rus, tmichaeldb, dusvyat, hamishfagg, MinuraPunchihewa, martyna-mindsdb, lucas-koontz |
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
import JobsApiClient from './jobsApiClient'; | ||
import { MindsDbError } from '../errors'; | ||
|
||
/** | ||
* Represents a MindsDB job and provides methods to build and create it. | ||
*/ | ||
export default class Job { | ||
/** API client to use for executing job operations. */ | ||
private jobsApiClient: JobsApiClient; | ||
|
||
/** Name of the job. */ | ||
name: string; | ||
|
||
/** Project the job belongs to. */ | ||
project: string; | ||
|
||
/** Accumulated queries to be executed by the job. */ | ||
private queries: string[]; | ||
|
||
/** Optional start date for the job. */ | ||
private start?: string; | ||
|
||
/** Optional end date for the job. */ | ||
private end?: string; | ||
|
||
/** Optional repetition frequency. */ | ||
private every?: string; | ||
|
||
/** Optional condition for job execution. */ | ||
private ifCondition?: string; | ||
|
||
/** | ||
* @param {JobsApiClient} jobsApiClient - API client to use for executing job operations. | ||
* @param {string} name - Name of the job. | ||
* @param {string} project - Project the job belongs to. | ||
*/ | ||
constructor(jobsApiClient: JobsApiClient, name: string, project: string) { | ||
this.jobsApiClient = jobsApiClient; | ||
this.name = name; | ||
this.project = project; | ||
this.queries = []; | ||
} | ||
|
||
/** | ||
* Adds a query to the job. | ||
* @param {string} query - The query to add. | ||
* @returns {Job} - The current job instance (for chaining). | ||
* @throws {MindsDbError} - If the query is invalid. | ||
*/ | ||
addQuery(query: string): Job { | ||
if (typeof query === 'string') { | ||
this.queries.push(query); | ||
} else { | ||
throw new MindsDbError('Invalid query type. Must be a string.'); | ||
} | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the start date for the job. | ||
* @param {string} start - The start date as a string. | ||
* @returns {Job} - The current job instance (for chaining). | ||
*/ | ||
setStart(start: string): Job { | ||
this.start = start; | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the end date for the job. | ||
* @param {string} end - The end date as a string. | ||
* @returns {Job} - The current job instance (for chaining). | ||
*/ | ||
setEnd(end: string): Job { | ||
this.end = end; | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the repetition frequency for the job. | ||
* @param {string} every - The repetition frequency. | ||
* @returns {Job} - The current job instance (for chaining). | ||
*/ | ||
setEvery(every: string): Job { | ||
this.every = every; | ||
return this; | ||
} | ||
|
||
/** | ||
* Sets the condition for job execution. | ||
* @param {string} ifCondition - The condition as a string. | ||
* @returns {Job} - The current job instance (for chaining). | ||
*/ | ||
setIfCondition(ifCondition: string): Job { | ||
this.ifCondition = ifCondition; | ||
return this; | ||
} | ||
|
||
/** | ||
* Creates the job in MindsDB. | ||
* @returns {Promise<void>} - Resolves when the job is created. | ||
* @throws {MindsDbError} - If job creation fails. | ||
*/ | ||
async createJob(): Promise<void> { | ||
if (this.queries.length === 0) { | ||
throw new MindsDbError('No queries added to the job.'); | ||
} | ||
const queryStr = this.queries.join(';\n'); | ||
await this.jobsApiClient.createJob( | ||
this.name, | ||
this.project, | ||
queryStr, | ||
this.start, | ||
this.end, | ||
this.every, | ||
this.ifCondition | ||
); | ||
} | ||
|
||
/** | ||
* Deletes the job from MindsDB. | ||
* @returns {Promise<void>} - Resolves when the job is deleted. | ||
* @throws {MindsDbError} - If job deletion fails. | ||
*/ | ||
async deleteJob(): Promise<void> { | ||
await this.jobsApiClient.deleteJob(this.name, this.project); | ||
} | ||
|
||
/** | ||
* Drops (deletes) a job from MindsDB by name. | ||
* @param {string} name - Name of the job to drop. | ||
* @param {string} project - Project the job belongs to. | ||
* @returns {Promise<void>} - Resolves when the job is dropped. | ||
* @throws {MindsDbError} - Something went wrong while dropping the job. | ||
*/ | ||
async dropJob(name: string, project: string = "mindsdb"): Promise<void> { | ||
await this.jobsApiClient.dropJob(name, project); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
import Job from './job'; | ||
|
||
/** | ||
* Abstract class outlining Job API operations supported by the SDK. | ||
*/ | ||
export default abstract class JobsApiClient { | ||
/** | ||
* Creates a new Job instance for building and creating a job. | ||
* @param {string} name - Name of the job. | ||
* @param {string} project - Project the job belongs to. | ||
* @returns {Job} - A new Job instance. | ||
*/ | ||
abstract create(name: string, project: string): Job; | ||
|
||
/** | ||
* Internal method to create the job in MindsDB. | ||
* @param {string} name - Name of the job to create. | ||
* @param {string} project - Project the job will be created in. | ||
* @param {string} query - Queries to be executed by the job. | ||
* @param {string} [start] - Optional start date for the job. | ||
* @param {string} [end] - Optional end date for the job. | ||
* @param {string} [every] - Optional repetition frequency. | ||
* @param {string} [ifCondition] - Optional condition for job execution. | ||
* @returns {Promise<void>} - Resolves when the job is created. | ||
* @throws {MindsDbError} - Something went wrong while creating the job. | ||
*/ | ||
abstract createJob( | ||
name: string, | ||
project: string, | ||
query: string, | ||
start?: string, | ||
end?: string, | ||
every?: string, | ||
ifCondition?: string | ||
): Promise<void>; | ||
|
||
/** | ||
* Internal method to delete the job in MindsDB. | ||
* @param {string} name - Name of the job to delete. | ||
* @param {string} project - Project the job will be deleted. | ||
* @returns {Promise<void>} - Resolves when the job is deleted. | ||
* @throws {MindsDbError} - Something went wrong while deleting the job. | ||
*/ | ||
abstract deleteJob( | ||
name: string, | ||
project: string | ||
): Promise<void> | ||
|
||
/** | ||
* Drops (deletes) a job from MindsDB by name. | ||
* @param {string} name - Name of the job to drop. | ||
* @param {string} project - Project the job belongs to. | ||
* @returns {Promise<void>} - Resolves when the job is dropped. | ||
* @throws {MindsDbError} - Something went wrong while dropping the job. | ||
*/ | ||
abstract dropJob(name: string, project: string): Promise<void>; | ||
|
||
/** | ||
* Lists all jobs from MindsDB. | ||
* @param {string} name - Name of the job. | ||
* @param {string} project - Project the job belongs to. | ||
* @returns {Promise<void>} - Resolves after all the jobs are listed. | ||
* @throws {MindsDbError} - Something went wrong while listing the job. | ||
*/ | ||
abstract list(name?: string, project?: string): Promise<Array<Job>>; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
import JobsRestApiClient from './jobsRestApiClient'; | ||
|
||
export default { JobsRestApiClient }; |
Oops, something went wrong.