Skip to content
This repository has been archived by the owner on Jun 6, 2021. It is now read-only.

Commit

Permalink
Merge pull request #459 from 3846masa/fix/cursor-undefined
Browse files Browse the repository at this point in the history
Fix infinity loop when search albums
  • Loading branch information
3846masa authored Jan 18, 2020
2 parents 6ac0a37 + af40fc6 commit a5209b5
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 16 deletions.
20 changes: 6 additions & 14 deletions src/GPhotos.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import util from 'util';
import { CookieJar } from 'tough-cookie';
import { Nullable, isNotNull, isNull } from 'option-t/cjs/Nullable';
import { Maybe, isNotNullAndUndefined } from 'option-t/cjs/Maybe';

import { signinViaPuppeteer } from './signin_via_puppeteer';
import { Requestor } from './Requestor';
Expand Down Expand Up @@ -40,7 +41,7 @@ class GPhotos {
const {
Z5xsfc: [albumInfoList, nextCursor],
} = await this.requestor.sendBatchExecute<{
Z5xsfc: [Nullable<any[]>, Nullable<string>];
Z5xsfc: [Nullable<any[]>, Maybe<string>];
}>({
queries: {
Z5xsfc: [cursor, null, null, null, 1],
Expand All @@ -60,7 +61,7 @@ class GPhotos {
});
});

return { results: albumList, nextCursor };
return { results: albumList, nextCursor: isNotNullAndUndefined(nextCursor) ? nextCursor : null };
}

async searchAlbum({ title }: { title: string }): Promise<Nullable<GPhotosAlbum>> {
Expand All @@ -81,17 +82,13 @@ class GPhotos {
}

async createAlbum({ title }: { title: string }): Promise<GPhotosAlbum> {
const {
results: [latestPhoto],
} = await this.fetchPhotoList({ cursor: null });

const {
OXvT9d: [[albumId]],
} = await this.requestor.sendBatchExecute<{
OXvT9d: [[string]];
}>({
queries: {
OXvT9d: [title, null, 1, [[[latestPhoto.id]]]],
OXvT9d: [title, null, 2, []],
},
});

Expand All @@ -107,11 +104,6 @@ class GPhotos {
{ requestor: this.requestor },
);

const {
results: [insertedPhoto],
} = await album.fetchPhotoList({ cursor: null });
await album.remove(insertedPhoto);

return album;
}

Expand All @@ -129,7 +121,7 @@ class GPhotos {
const {
lcxiM: [photoInfoList, nextCursor],
} = await this.requestor.sendBatchExecute<{
lcxiM: [any[], Nullable<string>];
lcxiM: [any[], Maybe<string>];
}>({
queries: {
lcxiM: [cursor, null, null, null, 1],
Expand All @@ -140,7 +132,7 @@ class GPhotos {
return new GPhotosPhoto(GPhotosPhoto.parseInfo(info), { requestor: this.requestor });
});

return { results: photoList, nextCursor };
return { results: photoList, nextCursor: isNotNullAndUndefined(nextCursor) ? nextCursor : null };
}

async upload({
Expand Down
5 changes: 3 additions & 2 deletions src/GPhotosAlbum.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import util from 'util';
import { Nullable } from 'option-t/cjs/Nullable';
import { Maybe, isNotNullAndUndefined } from 'option-t/cjs/Maybe';

import { Requestor } from './Requestor';
import { GPhotosPhoto } from './GPhotosPhoto';
Expand Down Expand Up @@ -73,7 +74,7 @@ class GPhotosAlbum {
const {
snAcKc: [, photoInfoList, nextCursor],
} = await this.requestor.sendBatchExecute<{
snAcKc: [unknown, any[], Nullable<string>];
snAcKc: [unknown, any[], Maybe<string>];
}>({
queries: {
snAcKc: [this.id, cursor, null, null, 0],
Expand All @@ -84,7 +85,7 @@ class GPhotosAlbum {
return new GPhotosPhoto(GPhotosPhoto.parseInfo(info), { requestor: this.requestor });
});

return { results: photoList, nextCursor };
return { results: photoList, nextCursor: isNotNullAndUndefined(nextCursor) ? nextCursor : null };
}

async delete(): Promise<void> {
Expand Down

0 comments on commit a5209b5

Please sign in to comment.