Added field user_id verification
This commit is contained in:
parent
9870b874a7
commit
4d880c01d0
2 changed files with 16 additions and 5 deletions
|
|
@ -15,5 +15,7 @@ export async function loadEntries(date: string): Promise<TimeEntry[]> {
|
||||||
if (!resp || resp.status !== 200 || !resp.data || !resp.data.time_entries) {
|
if (!resp || resp.status !== 200 || !resp.data || !resp.data.time_entries) {
|
||||||
throw new Error('Не удалось загрузить записи за дату');
|
throw new Error('Не удалось загрузить записи за дату');
|
||||||
}
|
}
|
||||||
return resp.data.time_entries;
|
return resp.data.time_entries.filter((entry) => {
|
||||||
|
return entry.user.id === config.redmine.user_id;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -34,10 +34,13 @@ function backupEntries(entries: Record<string, any>[]): void {
|
||||||
fs.writeFileSync(fileName, content, {encoding: "utf8"});
|
fs.writeFileSync(fileName, content, {encoding: "utf8"});
|
||||||
}
|
}
|
||||||
|
|
||||||
async function deleteEntries(entries: Record<string, any>[]): Promise<void> {
|
async function deleteEntries(entries: Record<string, any>[], userId: any): Promise<void> {
|
||||||
let i: number;
|
let i: number;
|
||||||
for (i = 0; i < entries.length; i++) {
|
for (i = 0; i < entries.length; i++) {
|
||||||
const entry = entries[i];
|
const entry = entries[i];
|
||||||
|
if (entry?.user?.id != userId) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
const url = `${config.redmine.url}/time_entries/${entry.id}.xml`;
|
const url = `${config.redmine.url}/time_entries/${entry.id}.xml`;
|
||||||
if (args['dry']) {
|
if (args['dry']) {
|
||||||
console.log('Delete time entry:', {url, entry});
|
console.log('Delete time entry:', {url, entry});
|
||||||
|
|
@ -48,7 +51,7 @@ async function deleteEntries(entries: Record<string, any>[]): Promise<void> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function cleanTimeEntries(items: TimeEntryForRedmine[]): Promise<void> {
|
async function cleanTimeEntries(items: TimeEntryForRedmine[], userId: any): Promise<void> {
|
||||||
const dates = getUniqDates(items);
|
const dates = getUniqDates(items);
|
||||||
for (let i = 0; i < dates.length; i++) {
|
for (let i = 0; i < dates.length; i++) {
|
||||||
const date = dates[i];
|
const date = dates[i];
|
||||||
|
|
@ -61,7 +64,7 @@ async function cleanTimeEntries(items: TimeEntryForRedmine[]): Promise<void> {
|
||||||
}
|
}
|
||||||
backupEntries(entries);
|
backupEntries(entries);
|
||||||
try {
|
try {
|
||||||
await deleteEntries(entries);
|
await deleteEntries(entries, userId);
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
console.error(`Ошибка при удалении записей на ${date}`, ex);
|
console.error(`Ошибка при удалении записей на ${date}`, ex);
|
||||||
return;
|
return;
|
||||||
|
|
@ -135,7 +138,13 @@ export async function save(): Promise<void> {
|
||||||
|
|
||||||
if (args['rewrite']) {
|
if (args['rewrite']) {
|
||||||
console.log('Очистка существующих записей...')
|
console.log('Очистка существующих записей...')
|
||||||
await cleanTimeEntries(items);
|
const userId = config.redmine.user_id;
|
||||||
|
if (!userId) {
|
||||||
|
console.error('В конфигурационном файле не указан user_id');
|
||||||
|
process.exit(1);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
await cleanTimeEntries(items, userId);
|
||||||
console.log('Очистка существующих записей завершена')
|
console.log('Очистка существующих записей завершена')
|
||||||
}
|
}
|
||||||
console.log('Сохранение новых записей...');
|
console.log('Сохранение новых записей...');
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue