diff options
author | dklawren <dklawren@users.noreply.github.com> | 2018-07-27 16:17:50 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-27 16:17:50 +0200 |
commit | 694a37b9debdf280d279b39b44329adda5caff40 (patch) | |
tree | e9e6cb6cd7bfabf81ed1012a96c1ac8f2f546153 /extensions/PhabBugz/lib/User.pm | |
parent | acde857e4c2b250210a7dc7fe26ce6c382616c76 (diff) | |
download | bugzilla-694a37b9debdf280d279b39b44329adda5caff40.tar.gz bugzilla-694a37b9debdf280d279b39b44329adda5caff40.tar.xz |
Bug 1478540 - Update User.pm to load more than 100 users by using the paging functionality of Conduit API
Diffstat (limited to 'extensions/PhabBugz/lib/User.pm')
-rw-r--r-- | extensions/PhabBugz/lib/User.pm | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/extensions/PhabBugz/lib/User.pm b/extensions/PhabBugz/lib/User.pm index 9d4e9eef4..1bf1a842d 100644 --- a/extensions/PhabBugz/lib/User.pm +++ b/extensions/PhabBugz/lib/User.pm @@ -131,14 +131,18 @@ sub match { attachments => { 'external-accounts' => 1 } }; + # We can only fetch 100 users at a time so we need to do this in lumps my $phab_users = []; - my $result = request( 'user.search', $data ); - - if ( exists $result->{result}{data} && @{ $result->{result}{data} } ) { - foreach my $user ( @{ $result->{result}{data} } ) { - push @$phab_users, $class->new($user); + my $result; + do { + $result = request( 'user.search', $data ); + if ( exists $result->{result}{data} && @{ $result->{result}{data} } ) { + foreach my $user ( @{ $result->{result}{data} } ) { + push @$phab_users, $class->new($user); + } } - } + $data->{after} = $result->{cursor}->{after}; + } while ($result->{cursor}->{after}); return $phab_users; } |