mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-25 14:08:19 +01:00
First cut at diffusion.getcommits method
This commit is contained in:
parent
d7c27dafd2
commit
ef5456b15f
3 changed files with 212 additions and 0 deletions
|
@ -85,6 +85,7 @@ phutil_register_library_map(array(
|
||||||
'ConduitAPI_differential_parsecommitmessage_Method' => 'applications/conduit/method/differential/parsecommitmessage',
|
'ConduitAPI_differential_parsecommitmessage_Method' => 'applications/conduit/method/differential/parsecommitmessage',
|
||||||
'ConduitAPI_differential_setdiffproperty_Method' => 'applications/conduit/method/differential/setdiffproperty',
|
'ConduitAPI_differential_setdiffproperty_Method' => 'applications/conduit/method/differential/setdiffproperty',
|
||||||
'ConduitAPI_differential_updaterevision_Method' => 'applications/conduit/method/differential/updaterevision',
|
'ConduitAPI_differential_updaterevision_Method' => 'applications/conduit/method/differential/updaterevision',
|
||||||
|
'ConduitAPI_diffusion_getcommits_Method' => 'applications/conduit/method/diffusion/getcommits',
|
||||||
'ConduitAPI_file_upload_Method' => 'applications/conduit/method/file/upload',
|
'ConduitAPI_file_upload_Method' => 'applications/conduit/method/file/upload',
|
||||||
'ConduitAPI_user_find_Method' => 'applications/conduit/method/user/find',
|
'ConduitAPI_user_find_Method' => 'applications/conduit/method/user/find',
|
||||||
'ConduitAPI_user_whoami_Method' => 'applications/conduit/method/user/whoami',
|
'ConduitAPI_user_whoami_Method' => 'applications/conduit/method/user/whoami',
|
||||||
|
@ -528,6 +529,7 @@ phutil_register_library_map(array(
|
||||||
'ConduitAPI_differential_parsecommitmessage_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_differential_parsecommitmessage_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_differential_setdiffproperty_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_differential_setdiffproperty_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_differential_updaterevision_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_differential_updaterevision_Method' => 'ConduitAPIMethod',
|
||||||
|
'ConduitAPI_diffusion_getcommits_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_file_upload_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_file_upload_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_user_find_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_user_find_Method' => 'ConduitAPIMethod',
|
||||||
'ConduitAPI_user_whoami_Method' => 'ConduitAPIMethod',
|
'ConduitAPI_user_whoami_Method' => 'ConduitAPIMethod',
|
||||||
|
|
|
@ -0,0 +1,190 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2011 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
class ConduitAPI_diffusion_getcommits_Method extends ConduitAPIMethod {
|
||||||
|
|
||||||
|
public function getMethodDescription() {
|
||||||
|
return "Retrieve Diffusion commit information.";
|
||||||
|
}
|
||||||
|
|
||||||
|
public function defineParamTypes() {
|
||||||
|
return array(
|
||||||
|
'commits' => 'required list<string>',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function defineReturnType() {
|
||||||
|
return 'nonempty list<dict<string, wild>>';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function defineErrorTypes() {
|
||||||
|
return array(
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function execute(ConduitAPIRequest $request) {
|
||||||
|
|
||||||
|
$results = array();
|
||||||
|
|
||||||
|
$commits = $request->getValue('commits');
|
||||||
|
$commits = array_fill_keys($commits, array());
|
||||||
|
foreach ($commits as $name => $info) {
|
||||||
|
$matches = null;
|
||||||
|
if (!preg_match('/^r([A-Z]+)([0-9a-f]+)$/', $name, $matches)) {
|
||||||
|
$results[$name] = array(
|
||||||
|
'error' => 'ERR-UNPARSEABLE',
|
||||||
|
);
|
||||||
|
unset($commits[$name]);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$commits[$name] = array(
|
||||||
|
'callsign' => $matches[1],
|
||||||
|
'commitIdentifier' => $matches[2],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$commits) {
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
$callsigns = ipull($commits, 'callsign');
|
||||||
|
$callsigns = array_unique($callsigns);
|
||||||
|
$repos = id(new PhabricatorRepository())->loadAllWhere(
|
||||||
|
'callsign IN (%Ls)',
|
||||||
|
$callsigns);
|
||||||
|
$repos = mpull($repos, null, 'getCallsign');
|
||||||
|
|
||||||
|
foreach ($commits as $name => $info) {
|
||||||
|
$repo = idx($repos, $info['callsign']);
|
||||||
|
if (!$repo) {
|
||||||
|
$results[$name] = $info + array(
|
||||||
|
'error' => 'ERR-UNKNOWN-REPOSITORY',
|
||||||
|
);
|
||||||
|
unset($commits[$name]);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$commits[$name] += array(
|
||||||
|
'repositoryPHID' => $repo->getPHID(),
|
||||||
|
'repositoryID' => $repo->getID(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$commits) {
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
$conn_r = id(new PhabricatorRepositoryCommit())->establishConnection('r');
|
||||||
|
|
||||||
|
$groups = array();
|
||||||
|
foreach ($commits as $name => $commit) {
|
||||||
|
$groups[$commit['repositoryID']][] = $commit['commitIdentifier'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// NOTE: MySQL goes crazy and does a massive table scan if we build a more
|
||||||
|
// sensible version of this query. Make sure the query play is OK if you
|
||||||
|
// attempt to reduce the craziness here.
|
||||||
|
$query = array();
|
||||||
|
foreach ($groups as $repository_id => $identifiers) {
|
||||||
|
$query[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'SELECT * FROM %T WHERE repositoryID = %d
|
||||||
|
AND commitIdentifier IN (%Ls)',
|
||||||
|
id(new PhabricatorRepositoryCommit())->getTableName(),
|
||||||
|
$repository_id,
|
||||||
|
$identifiers);
|
||||||
|
}
|
||||||
|
$cdata = queryfx_all(
|
||||||
|
$conn_r,
|
||||||
|
'%Q',
|
||||||
|
implode(' UNION ALL ', $query));
|
||||||
|
|
||||||
|
$cobjs = id(new PhabricatorRepositoryCommit())->loadAllFromArray($cdata);
|
||||||
|
$cobjs = mgroup($cobjs, 'getRepositoryID', 'getCommitIdentifier');
|
||||||
|
foreach ($commits as $name => $commit) {
|
||||||
|
$repo_id = $commit['repositoryID'];
|
||||||
|
unset($commits[$name]['repositoryID']);
|
||||||
|
|
||||||
|
if (empty($cobjs[$commit['repositoryID']][$commit['commitIdentifier']])) {
|
||||||
|
$results[$name] = $commit + array(
|
||||||
|
'error' => 'ERR-UNKNOWN-COMMIT',
|
||||||
|
);
|
||||||
|
unset($commits[$name]);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$cobj_arr = $cobjs[$commit['repositoryID']][$commit['commitIdentifier']];
|
||||||
|
$cobj = head($cobj_arr);
|
||||||
|
|
||||||
|
$commits[$name] += array(
|
||||||
|
'epoch' => $cobj->getEpoch(),
|
||||||
|
'commitPHID' => $cobj->getPHID(),
|
||||||
|
'commitID' => $cobj->getID(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$commits) {
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
$commit_ids = ipull($commits, 'commitID');
|
||||||
|
$data = id(new PhabricatorRepositoryCommitData())->loadAllWhere(
|
||||||
|
'commitID in (%Ld)',
|
||||||
|
$commit_ids);
|
||||||
|
$data = mpull($data, null, 'getCommitID');
|
||||||
|
|
||||||
|
foreach ($commits as $name => $commit) {
|
||||||
|
if (isset($data[$commit['commitID']])) {
|
||||||
|
$dobj = $data[$commit['commitID']];
|
||||||
|
$commits[$name] += array(
|
||||||
|
'commitMessage' => $dobj->getCommitMessage(),
|
||||||
|
'commitDetails' => $dobj->getCommitDetails(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
unset($commits[$name]['commitID']);
|
||||||
|
}
|
||||||
|
|
||||||
|
$commit_phids = ipull($commits, 'commitPHID');
|
||||||
|
$rev_conn_r = id(new DifferentialRevision())->establishConnection('r');
|
||||||
|
$revs = queryfx_all(
|
||||||
|
$rev_conn_r,
|
||||||
|
'SELECT r.id id, r.phid phid, c.commitPHID commitPHID FROM %T r JOIN %T c
|
||||||
|
ON r.id = c.revisionID
|
||||||
|
WHERE c.commitPHID in (%Ls)',
|
||||||
|
id(new DifferentialRevision())->getTableName(),
|
||||||
|
DifferentialRevision::TABLE_COMMIT,
|
||||||
|
$commit_phids);
|
||||||
|
|
||||||
|
$revs = ipull($revs, null, 'commitPHID');
|
||||||
|
foreach ($commits as $name => $commit) {
|
||||||
|
if (isset($revs[$commit['commitPHID']])) {
|
||||||
|
$rev = $revs[$commit['commitPHID']];
|
||||||
|
$commits[$name] += array(
|
||||||
|
'differentialRevisionID' => 'D'.$rev['id'],
|
||||||
|
'differentialRevisionPHID' => $rev['phid'],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($commits as $name => $commit) {
|
||||||
|
$results[$name] = $commit;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/conduit/method/base');
|
||||||
|
phutil_require_module('phabricator', 'applications/differential/storage/revision');
|
||||||
|
phutil_require_module('phabricator', 'applications/repository/storage/commit');
|
||||||
|
phutil_require_module('phabricator', 'applications/repository/storage/commitdata');
|
||||||
|
phutil_require_module('phabricator', 'applications/repository/storage/repository');
|
||||||
|
phutil_require_module('phabricator', 'storage/qsprintf');
|
||||||
|
phutil_require_module('phabricator', 'storage/queryfx');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('ConduitAPI_diffusion_getcommits_Method.php');
|
Loading…
Add table
Reference in a new issue