Skip to content

Commit

Permalink
[Feature] The front-end is modified to support the cdc yaml api (#4177)
Browse files Browse the repository at this point in the history
  • Loading branch information
Mrart authored Jan 20, 2025
1 parent ad8395f commit 83d741a
Show file tree
Hide file tree
Showing 11 changed files with 79 additions and 26 deletions.
6 changes: 4 additions & 2 deletions streampark-console/streampark-console-webapp/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,8 @@
"vue": "^3.3.4",
"vue-i18n": "^9.2.2",
"vue-router": "^4.2.4",
"vue-types": "^5.1.0"
"vue-types": "^5.1.0",
"js-yaml": "^4.1.0"
},
"devDependencies": {
"@iconify/json": "^2.2.89",
Expand Down Expand Up @@ -118,7 +119,8 @@
"vite-plugin-theme": "^0.8.6",
"vite-plugin-windicss": "^1.9.1",
"vue-eslint-parser": "^9.3.1",
"vue-tsc": "^1.8.4"
"vue-tsc": "^1.8.4",
"js-yaml": "^4.1.0"
},
"engines": {
"node": ">=16.15.1 <= 18",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,7 @@ export enum JobTypeEnum {
JAR = 1,
SQL = 2,
PYFLINK = 3,
CDC = 4,
}

export enum ConfigTypeEnum {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -205,8 +205,10 @@ export default {
editStreamPark: {
success: 'update successful',
flinkSqlRequired: 'Flink Sql is required',
yamlRequired: 'Yaml is required',
appidCheck: 'appid can not be empty',
sqlCheck: 'SQL check error',
yamlCheck: 'Yaml check error',
},
operation: {
edit: 'Edit Job',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,8 @@ export default {
flinkSqlRequired: 'Flink Sql 为必填项',
appidCheck: 'appid 不能为空',
sqlCheck: 'SQL 检查错误',
yamlRequired: 'Yaml 不能为空',
yamlCheck: 'Yaml 检查错误',
},
operation: {
edit: '编辑作业',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -263,13 +263,15 @@
async function handleAppCreate(formValue: Recordable) {
try {
submitLoading.value = true;
if (formValue.jobType == JobTypeEnum.SQL) {
if (formValue.jobType == JobTypeEnum.SQL || formValue.jobType == JobTypeEnum.CDC) {
if (formValue.flinkSql == null || formValue.flinkSql.trim() === '') {
createMessage.warning(t('flink.app.editStreamPark.flinkSqlRequired'));
const errorMsg = formValue.jobType == JobTypeEnum.SQL ? t('flink.app.editStreamPark.flinkSqlRequired') : t('flink.app.editStreamPark.yamlRequired')
createMessage.warning(errorMsg);
} else {
const access = await flinkSql?.value?.handleVerifySql();
if (!access) {
createMessage.warning(t('flink.app.editStreamPark.sqlCheck'));
const errorMsg = formValue.jobType == JobTypeEnum.SQL ? t('flink.app.editStreamPark.sqlCheck') : t('flink.app.editStreamPark.yamlCheck')
createMessage.warning(errorMsg);
throw new Error(access);
}
}
Expand Down Expand Up @@ -316,6 +318,7 @@
v-model:value="model[field]"
:versionId="model['versionId']"
:suggestions="suggestions"
:jobType="Number(model['jobType'])"
@preview="(value) => openReviewDrawer(true, { value, suggestions })"
/>
</template>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -164,13 +164,15 @@
async function handleAppUpdate(values) {
try {
submitLoading.value = true;
if (app.jobType == JobTypeEnum.SQL) {
if (app.jobType == JobTypeEnum.SQL || app.jobType == JobTypeEnum.CDC) {
if (values.flinkSql == null || values.flinkSql.trim() === '') {
createMessage.warning(t('flink.app.editStreamPark.flinkSqlRequired'));
const errorMsg = app.jobType == JobTypeEnum.SQL ? t('flink.app.editStreamPark.flinkSqlRequired') : t('flink.app.editStreamPark.yamlRequired')
createMessage.warning(errorMsg);
} else {
const access = await flinkSql?.value?.handleVerifySql();
if (!access) {
createMessage.warning(t('flink.app.editStreamPark.sqlCheck'));
const errorMsg = app.jobType == JobTypeEnum.SQL ? t('flink.app.editStreamPark.sqlCheck') : t('flink.app.editStreamPark.yamlCheck')
createMessage.warning(errorMsg);
throw new Error(access);
}
handleSubmitSQL(values);
Expand Down Expand Up @@ -283,7 +285,7 @@
Object.assign(app, res);
Object.assign(defaultOptions, JSON.parse(app.options || '{}'));

if (app.jobType == JobTypeEnum.SQL) {
if (app.jobType == JobTypeEnum.SQL || app.jobType == JobTypeEnum.CDC) {
fetchFlinkHistory({ id: appId }).then((res) => {
flinkSqlHistory.value = res;
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -310,6 +310,7 @@
:options="[
{ label: 'JAR', value: JobTypeEnum.JAR },
{ label: 'SQL', value: JobTypeEnum.SQL },
{ label: 'FlinkCDC', value: JobTypeEnum.CDC },
]"
/>
</Form.Item>
Expand Down Expand Up @@ -349,6 +350,7 @@
<template v-if="column.dataIndex === 'jobName'">
<span class="app_type app_jar" v-if="record['jobType'] === JobTypeEnum.JAR"> JAR </span>
<span class="app_type app_sql" v-if="record['jobType'] === JobTypeEnum.SQL"> SQL </span>
<span class="app_type app_sql" v-if="record['jobType'] === JobTypeEnum.CDC"> CDC </span>
<span class="link cursor-pointer" @click="handleJobView(record)">
<Popover :title="t('common.detailText')">
<template #content>
Expand All @@ -361,6 +363,7 @@
<Tag color="blue">
<span v-if="record['jobType'] == JobTypeEnum.JAR"> JAR </span>
<span v-if="record['jobType'] == JobTypeEnum.SQL"> SQL </span>
<span v-if="record['jobType'] == JobTypeEnum.CDC"> FlinkCDC </span>
</Tag>
</div>
<div class="pt-2px flex">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,8 @@
import { format } from '../FlinkSqlFormatter';
import { useI18n } from '/@/hooks/web/useI18n';
import { useFullContent } from '/@/hooks/event/useFullscreen';
import { JobTypeEnum } from '/@/enums/flinkEnum';
import YAML from 'js-yaml';
const ButtonGroup = Button.Group;
const { t } = useI18n();

Expand Down Expand Up @@ -65,6 +67,9 @@
type: Array as PropType<Array<{ text: string; description: string }>>,
default: () => [],
},
jobType: {
type: Number
}
});
const defaultValue = '';

Expand All @@ -79,7 +84,23 @@
createMessage.error(t('flink.app.dependencyError'));
return false;
} else {
try {
console.log(props.jobType)
if (props.jobType === JobTypeEnum.CDC) {
try {
YAML.load(props.value);
verifyRes.verified = true;
verifyRes.errorMsg = '';
syntaxError();
return true;
} catch (error) {
verifyRes.errorStart = 0;
verifyRes.errorEnd = 0;
verifyRes.errorMsg = `${error.name}: ${error.reason} at line ${error.mark.line},cloumn ${error.mark.column}`;
syntaxError();
return false;
}
} else {
try {
const { data } = await fetchFlinkSqlVerify({
sql: props.value,
versionId: props.versionId,
Expand Down Expand Up @@ -111,6 +132,7 @@
console.error(error);
return false;
}
}
}
}

Expand Down Expand Up @@ -140,6 +162,9 @@
/* format */
function handleFormatSql() {
if (isEmpty(props.value)) return;
if (props.jobType === JobTypeEnum.CDC) {
return false;
}
const formatSql = format(props.value);
setContent(formatSql);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ export const useAppTableAction = (
sessionStorage.setItem('appPageNo', String(currentPageNo || 1));
flinkAppStore.setApplicationId(app.id);
if (app.appType == AppTypeEnum.STREAMPARK_FLINK) {
// jobType( 1 flinkJar 2: flinkSQL)
// jobType( 1 custom code 2: flinkSQL)
router.push({ path: '/flink/app/edit_streampark', query: { appId: app.id } });
} else if (app.appType == AppTypeEnum.APACHE_FLINK) {
//Apache Flink
Expand Down Expand Up @@ -314,6 +314,7 @@ export const useAppTableAction = (
{ label: 'JAR', value: JobTypeEnum.JAR },
{ label: 'SQL', value: JobTypeEnum.SQL },
{ label: 'PYFLINK', value: JobTypeEnum.PYFLINK },
{ label: 'FLINK CDC', value: JobTypeEnum.CDC },
],
onChange: handlePageDataReload.bind(null, false),
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -109,15 +109,15 @@ export const useCreateAndEditSchema = (
label: 'Flink SQL',
component: 'Input',
slot: 'flinkSql',
ifShow: ({ values }) => values?.jobType == JobTypeEnum.SQL,
ifShow: ({ values }) => values?.jobType == JobTypeEnum.SQL || values?.jobType == JobTypeEnum.CDC,
rules: [{ required: true, message: t('flink.app.addAppTips.flinkSqlIsRequiredMessage') }],
},
{
field: 'teamResource',
label: t('flink.app.resource'),
component: 'Select',
render: ({ model }) => renderStreamParkResource({ model, resources: unref(teamResource) }),
ifShow: ({ values }) => values.jobType == JobTypeEnum.SQL,
ifShow: ({ values }) => values.jobType == JobTypeEnum.SQL || values.jobType == JobTypeEnum.CDC,
},
{
field: 'dependency',
Expand All @@ -132,7 +132,7 @@ export const useCreateAndEditSchema = (
label: t('flink.app.appConf'),
component: 'Switch',
ifShow: ({ values }) =>
values?.jobType == JobTypeEnum.SQL && !isK8sDeployMode(values.deployMode),
(values?.jobType == JobTypeEnum.SQL || values?.jobType == JobTypeEnum.CDC) && !isK8sDeployMode(values.deployMode),
render({ model, field }) {
return renderIsSetConfig(model, field, registerConfDrawer, openConfDrawer);
},
Expand Down Expand Up @@ -477,7 +477,7 @@ export const useCreateAndEditSchema = (
component: 'InputTextArea',
defaultValue: '',
slot: 'args',
ifShow: ({ values }) => (edit?.mode ? true : values.jobType != JobTypeEnum.SQL),
ifShow: ({ values }) => (edit?.mode ? true : (values.jobType != JobTypeEnum.SQL && values.jobType != JobTypeEnum.CDC)),
},
{
field: 'hadoopUser',
Expand Down Expand Up @@ -510,10 +510,12 @@ export const useCreateAndEditSchema = (
icon: 'ant-design:code-outlined',
style: { color: '#108ee9' },
}),
h('span', { class: 'pl-8px' }, 'Flink JAR'),
h('span', { class: 'pl-8px' }, 'Custom Code'),
],
},
);
} else if(model.jobType == JobTypeEnum.CDC) {
return getAlertSvgIcon('fql', 'Flink CDC');
} else {
return getAlertSvgIcon('fql', 'Flink SQL');
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,8 +39,8 @@ const getJobTypeOptions = () => {
return [
{
label: h('div', {}, [
h(SvgIcon, { name: 'fjar', color: '#108ee9' }, ''),
h('span', { class: 'pl-10px' }, 'Flink JAR'),
h(SvgIcon, { name: 'code', color: '#108ee9' }, ''),
h('span', { class: 'pl-10px' }, 'Custom Code'),
]),
value: String(JobTypeEnum.JAR),
},
Expand All @@ -58,6 +58,13 @@ const getJobTypeOptions = () => {
]),
value: String(JobTypeEnum.PYFLINK),
},
{
label: h('div', {}, [
h(SvgIcon, { name: 'fql', color: '#108ee9' }, ''),
h('span', { class: 'pl-10px' }, 'Flink CDC'),
]),
value: String(JobTypeEnum.CDC),
},
];
};

Expand Down Expand Up @@ -108,7 +115,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
placeholder: t('flink.app.addAppTips.jobTypePlaceholder'),
options: getJobTypeOptions(),
onChange: (value) => {
if (value != JobTypeEnum.SQL) {
if (value != JobTypeEnum.SQL && value != JobTypeEnum.CDC) {
formModel.resourceFrom = String(ResourceFromEnum.PROJECT);
}
},
Expand All @@ -126,23 +133,23 @@ export const useCreateSchema = (dependencyRef: Ref) => {
component: 'Select',
render: ({ model }) => renderResourceFrom(model),
rules: [{ required: true, message: t('flink.app.addAppTips.resourceFromMessage') }],
show: ({ values }) => values?.jobType != JobTypeEnum.SQL,
show: ({ values }) => values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC,
},
{
field: 'uploadJobJar',
label: t('flink.app.selectJobJar'),
component: 'Select',
render: ({ model }) => renderStreamParkJarApp({ model, resources: unref(teamResource) }),
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values?.resourceFrom == ResourceFromEnum.UPLOAD,
values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC && values?.resourceFrom == ResourceFromEnum.UPLOAD,
},
{
field: 'mainClass',
label: t('flink.app.mainClass'),
component: 'Input',
componentProps: { placeholder: t('flink.app.addAppTips.mainClassPlaceholder') },
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values?.resourceFrom == ResourceFromEnum.UPLOAD,
values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC && values?.resourceFrom == ResourceFromEnum.UPLOAD,
rules: [{ required: true, message: t('flink.app.addAppTips.mainClassIsRequiredMessage') }],
},
{
Expand Down Expand Up @@ -170,7 +177,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
},
},
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values.resourceFrom != ResourceFromEnum.UPLOAD,
values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC && values.resourceFrom != ResourceFromEnum.UPLOAD,
rules: [{ required: true, message: t('flink.app.addAppTips.projectIsRequiredMessage') }],
},
{
Expand All @@ -193,8 +200,8 @@ export const useCreateSchema = (dependencyRef: Ref) => {
},
};
},
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values?.resourceFrom != ResourceFromEnum.UPLOAD,
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC && values?.resourceFrom != ResourceFromEnum.UPLOAD,
rules: [{ required: true, message: t('flink.app.addAppTips.projectIsRequiredMessage') }],
},
{
Expand Down Expand Up @@ -225,7 +232,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
};
},
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL && values?.resourceFrom != ResourceFromEnum.UPLOAD,
values?.jobType != JobTypeEnum.SQL && values?.jobType != JobTypeEnum.CDC && values?.resourceFrom != ResourceFromEnum.UPLOAD,
dynamicRules: () => [
{ required: true, message: t('flink.app.addAppTips.appTypeIsRequiredMessage') },
],
Expand All @@ -251,6 +258,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
},
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL &&
values?.jobType != JobTypeEnum.CDC &&
values?.resourceFrom != ResourceFromEnum.UPLOAD &&
values.appType == String(AppTypeEnum.APACHE_FLINK),
rules: [{ required: true, message: t('flink.app.addAppTips.programJarIsRequiredMessage') }],
Expand All @@ -262,6 +270,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
componentProps: { placeholder: t('flink.app.addAppTips.mainClassPlaceholder') },
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL &&
values?.jobType != JobTypeEnum.CDC &&
values?.resourceFrom != ResourceFromEnum.UPLOAD &&
values.appType == String(AppTypeEnum.APACHE_FLINK),
rules: [{ required: true, message: t('flink.app.addAppTips.mainClassIsRequiredMessage') }],
Expand Down Expand Up @@ -289,6 +298,7 @@ export const useCreateSchema = (dependencyRef: Ref) => {
},
ifShow: ({ values }) =>
values?.jobType != JobTypeEnum.SQL &&
values?.jobType != JobTypeEnum.CDC &&
values?.resourceFrom != ResourceFromEnum.UPLOAD &&
values.appType == String(AppTypeEnum.STREAMPARK_FLINK),
dynamicRules: () => [{ required: true, validator: handleCheckConfig }],
Expand Down

0 comments on commit 83d741a

Please sign in to comment.