Make repo migration cancelable and fix various bugs (#24605)
Replace #12917 Close #24601 Close #12845     --------- Co-authored-by: Yarden Shoham <git@yardenshoham.com> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Giteabot <teabot@gitea.io>main
parent
58dfaf3a75
commit
f6e029e6c7
@ -1,51 +1,55 @@
|
|||||||
import $ from 'jquery';
|
import $ from 'jquery';
|
||||||
import {hideElem, showElem} from '../utils/dom.js';
|
import {hideElem, showElem} from '../utils/dom.js';
|
||||||
|
|
||||||
const {appSubUrl, csrfToken} = window.config;
|
const {appSubUrl} = window.config;
|
||||||
|
|
||||||
export function initRepoMigrationStatusChecker() {
|
export function initRepoMigrationStatusChecker() {
|
||||||
const migrating = $('#repo_migrating');
|
const $repoMigrating = $('#repo_migrating');
|
||||||
hideElem($('#repo_migrating_failed'));
|
if (!$repoMigrating.length) return;
|
||||||
hideElem($('#repo_migrating_failed_image'));
|
|
||||||
hideElem($('#repo_migrating_progress_message'));
|
const task = $repoMigrating.attr('data-migrating-task-id');
|
||||||
if (migrating) {
|
|
||||||
const task = migrating.attr('task');
|
// returns true if the refresh still need to be called after a while
|
||||||
if (task === undefined) {
|
const refresh = async () => {
|
||||||
return;
|
const res = await fetch(`${appSubUrl}/user/task/${task}`);
|
||||||
|
if (res.status !== 200) return true; // continue to refresh if network error occurs
|
||||||
|
|
||||||
|
const data = await res.json();
|
||||||
|
|
||||||
|
// for all status
|
||||||
|
if (data.message) {
|
||||||
|
$('#repo_migrating_progress_message').text(data.message);
|
||||||
}
|
}
|
||||||
$.ajax({
|
|
||||||
type: 'GET',
|
// TaskStatusFinished
|
||||||
url: `${appSubUrl}/user/task/${task}`,
|
if (data.status === 4) {
|
||||||
data: {
|
|
||||||
_csrf: csrfToken,
|
|
||||||
},
|
|
||||||
complete(xhr) {
|
|
||||||
if (xhr.status === 200 && xhr.responseJSON) {
|
|
||||||
if (xhr.responseJSON.status === 4) {
|
|
||||||
window.location.reload();
|
window.location.reload();
|
||||||
return;
|
return false;
|
||||||
} else if (xhr.responseJSON.status === 3) {
|
|
||||||
hideElem($('#repo_migrating_progress'));
|
|
||||||
hideElem($('#repo_migrating'));
|
|
||||||
showElem($('#repo_migrating_failed'));
|
|
||||||
showElem($('#repo_migrating_failed_image'));
|
|
||||||
$('#repo_migrating_failed_error').text(xhr.responseJSON.message);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
if (xhr.responseJSON.message) {
|
|
||||||
showElem($('#repo_migrating_progress_message'));
|
// TaskStatusFailed
|
||||||
$('#repo_migrating_progress_message').text(xhr.responseJSON.message);
|
if (data.status === 3) {
|
||||||
}
|
hideElem('#repo_migrating_progress');
|
||||||
setTimeout(() => {
|
hideElem('#repo_migrating');
|
||||||
initRepoMigrationStatusChecker();
|
showElem('#repo_migrating_failed');
|
||||||
}, 2000);
|
showElem('#repo_migrating_failed_image');
|
||||||
return;
|
$('#repo_migrating_failed_error').text(data.message);
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
hideElem($('#repo_migrating_progress'));
|
|
||||||
hideElem($('#repo_migrating'));
|
return true; // continue to refresh
|
||||||
showElem($('#repo_migrating_failed'));
|
};
|
||||||
showElem($('#repo_migrating_failed_image'));
|
|
||||||
|
const syncTaskStatus = async () => {
|
||||||
|
let doNextRefresh = true;
|
||||||
|
try {
|
||||||
|
doNextRefresh = await refresh();
|
||||||
|
} finally {
|
||||||
|
if (doNextRefresh) {
|
||||||
|
setTimeout(syncTaskStatus, 2000);
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
syncTaskStatus(); // no await
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue