Skip to content

Commit

Permalink
Revert "Add quota manager (ericyd#89)" (ericyd#103)
Browse files Browse the repository at this point in the history
This reverts commit 1da19b0.
  • Loading branch information
ericyd authored Apr 22, 2019
1 parent 8c4251d commit 66cb51c
Show file tree
Hide file tree
Showing 17 changed files with 477 additions and 605 deletions.
360 changes: 170 additions & 190 deletions dist/application.gs

Large diffs are not rendered by default.

36 changes: 21 additions & 15 deletions lib/FileService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,9 @@
**********************************************/

import { Util } from './Util';
import Logging from './util/Logging';
import { getMetadata } from './public';
import Properties from './Properties';
import QuotaManager from './QuotaManager';
import Timer from './Timer';
import GDriveService from './GDriveService';
import API from './API';
import MimeType from './MimeType';
Expand All @@ -15,18 +14,18 @@ import ErrorMessages from './ErrorMessages';

export default class FileService {
gDriveService: GDriveService;
quotaManager: QuotaManager;
timer: Timer;
properties: Properties;
nativeMimeTypes: string[];
maxNumberOfAttempts: number;

constructor(
gDriveService: GDriveService,
quotaManager: QuotaManager,
timer: Timer,
properties: Properties
) {
this.gDriveService = gDriveService;
this.quotaManager = quotaManager;
this.timer = timer;
this.properties = properties;
this.nativeMimeTypes = [
MimeType.DOC,
Expand Down Expand Up @@ -86,7 +85,7 @@ export default class FileService {
try {
permissions = this.gDriveService.getPermissions(srcId).items;
} catch (e) {
Logging.log({ status: Util.composeErrorMsg(e) });
Util.log({ status: Util.composeErrorMsg(e) });
}

// copy editors, viewers, and commenters from src file to dest file
Expand Down Expand Up @@ -150,7 +149,7 @@ export default class FileService {
try {
destPermissions = this.gDriveService.getPermissions(destId).items;
} catch (e) {
Logging.log({ status: Util.composeErrorMsg(e) });
Util.log({ status: Util.composeErrorMsg(e) });
}

if (destPermissions && destPermissions.length > 0) {
Expand All @@ -177,17 +176,23 @@ export default class FileService {
* Destination folder must be set to the parent of the first leftover item.
* The list of leftover items is an equivalent array to fileList returned from the getFiles() query
*/
handleLeftovers(ss: GoogleAppsScript.Spreadsheet.Sheet): void {
handleLeftovers(
userProperties: GoogleAppsScript.Properties.UserProperties,
ss: GoogleAppsScript.Spreadsheet.Sheet
): void {
if (Util.hasSome(this.properties.leftovers, 'items')) {
this.properties.currFolderId = this.properties.leftovers.items[0].parents[0].id;
this.processFileList(this.properties.leftovers.items, ss);
this.processFileList(this.properties.leftovers.items, userProperties, ss);
}
}

handleRetries(ss: GoogleAppsScript.Spreadsheet.Sheet): void {
handleRetries(
userProperties: GoogleAppsScript.Properties.UserProperties,
ss: GoogleAppsScript.Spreadsheet.Sheet
): void {
if (Util.hasSome(this.properties, 'retryQueue')) {
this.properties.currFolderId = this.properties.retryQueue[0].parents[0].id;
this.processFileList(this.properties.retryQueue, ss);
this.processFileList(this.properties.retryQueue, userProperties, ss);
}
}

Expand All @@ -200,24 +205,25 @@ export default class FileService {
*/
processFileList(
items: gapi.client.drive.FileResource[],
userProperties: GoogleAppsScript.Properties.UserProperties,
ss: GoogleAppsScript.Spreadsheet.Sheet
): void {
while (items.length > 0 && this.quotaManager.canContinue()) {
while (items.length > 0 && this.timer.canContinue()) {
// Get next file from passed file list.
var item = items.pop();

if (
item.numberOfAttempts &&
item.numberOfAttempts > this.maxNumberOfAttempts
) {
Logging.logCopyError(ss, item.error, item, this.properties.timeZone);
Util.logCopyError(ss, item.error, item, this.properties.timeZone);
continue;
}

// Copy each (files and folders are both represented the same in Google Drive)
try {
var newfile = this.copyFile(item);
Logging.logCopySuccess(ss, newfile, this.properties.timeZone);
Util.logCopySuccess(ss, newfile, this.properties.timeZone);
} catch (e) {
this.properties.retryQueue.unshift({
id: item.id,
Expand Down Expand Up @@ -246,7 +252,7 @@ export default class FileService {
}

// Update current runtime and user stop flag
this.quotaManager.update;
this.timer.update(userProperties);
}
}

Expand Down
25 changes: 0 additions & 25 deletions lib/QuotaManager.ts

This file was deleted.

15 changes: 9 additions & 6 deletions lib/Timer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,40 +11,43 @@ export default class Timer {
static MAX_RUNTIME_PER_DAY: number = 88 * 1000 * 60;
static MAX_RUNTIME: number = 4.7 * 1000 * 60;
// durations used for setting Triggers
static ONE_DAY: number = 24 * 60 * 60 * 1000;
static SIX_MINUTES: number = 6.2 * 1000 * 60;
static oneDay: number = 24 * 60 * 60 * 1000;
static sixMinutes: number = 6.2 * 1000 * 60;

START_TIME: number;
runtime: number;
timeIsUp: boolean;
stop: boolean;

constructor() {
this.START_TIME = new Date().getTime();
this.runtime = 0;
this.timeIsUp = false;
this.stop = false;

return this;
}

/**
* Update current time
*/
update(): void {
update(userProperties: GoogleAppsScript.Properties.UserProperties): void {
this.runtime = Timer.now() - this.START_TIME;
this.timeIsUp = this.runtime >= Timer.MAX_RUNTIME;
this.stop = userProperties.getProperty('stop') == 'true';
}

canContinue(): boolean {
return !this.timeIsUp;
return !this.timeIsUp && !this.stop;
}

/**
* Calculate how far in the future the trigger should be set
*/
calculateTriggerDuration(properties: Properties): number {
return properties.checkMaxRuntime()
? Timer.ONE_DAY
: Timer.SIX_MINUTES - this.runtime;
? Timer.oneDay
: Timer.sixMinutes - this.runtime;
}

static now(): number {
Expand Down
5 changes: 2 additions & 3 deletions lib/TriggerService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@

import { Util } from './Util';
import Timer from './Timer';
import Logging from './util/Logging';

export default class TriggerService {
/**
Expand All @@ -14,7 +13,7 @@ export default class TriggerService {
static createTrigger(duration: number): void {
// default is 6.2 minutes from now
// Timer will stop execution after 4.7 minutes, so this gives about 1.5 minutes buffer
duration = duration || Timer.SIX_MINUTES;
duration = duration || Timer.sixMinutes;
var trigger = ScriptApp.newTrigger('copy')
.timeBased()
.after(duration)
Expand Down Expand Up @@ -47,7 +46,7 @@ export default class TriggerService {
}
}
} catch (e) {
Logging.log({ status: Util.composeErrorMsg(e) });
Util.log({ status: Util.composeErrorMsg(e) });
}
}
}
Expand Down
Loading

0 comments on commit 66cb51c

Please sign in to comment.