1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-18 18:51:12 +01:00

Add basic edit history to herald rules

Summary:
Add a very basic edit history table to herald rules.  This table is updated
whenever saving a herald rule.  The contents of the save are not examined, and
the edit history contains no information about the rule itself *yet*.  Edit
history can be viewed by anyone through /herald/history/<rule id>/.

Task ID: #

Blame Rev:

Test Plan:
Made a test rule, saved some stuff.

Revert Plan:

Tags:

Reviewers: epriestley, jungejason

Reviewed By: epriestley

CC: zizzy, aran, xela, epriestley

Differential Revision: https://secure.phabricator.com/D1387
This commit is contained in:
awyler 2012-01-30 11:51:23 -08:00
parent 780397aa71
commit 56df2bc7be
16 changed files with 283 additions and 6 deletions

View file

@ -0,0 +1,8 @@
CREATE TABLE phabricator_herald.herald_ruleedit (
id int unsigned not null auto_increment primary key,
ruleID int unsigned not null,
editorPHID varchar(64) BINARY not null,
dateCreated int unsigned not null,
dateModified int unsigned not null,
KEY (ruleID, dateCreated)
) ENGINE=InnoDB;

View file

@ -332,14 +332,13 @@ celerity_register_resource_map(array(
), ),
0 => 0 =>
array( array(
'uri' => '/res/b6096fdd/rsrc/js/javelin/lib/__tests__/URI.js', 'uri' => '/res/14c48a9f/rsrc/js/javelin/lib/__tests__/behavior.js',
'type' => 'js', 'type' => 'js',
'requires' => 'requires' =>
array( array(
0 => 'javelin-uri', 0 => 'javelin-behavior',
1 => 'javelin-php-serializer',
), ),
'disk' => '/rsrc/js/javelin/lib/__tests__/URI.js', 'disk' => '/rsrc/js/javelin/lib/__tests__/behavior.js',
), ),
'javelin-behavior-aphront-basic-tokenizer' => 'javelin-behavior-aphront-basic-tokenizer' =>
array( array(

View file

@ -358,6 +358,9 @@ phutil_register_library_map(array(
'HeraldRepetitionPolicyConfig' => 'applications/herald/config/repetitionpolicy', 'HeraldRepetitionPolicyConfig' => 'applications/herald/config/repetitionpolicy',
'HeraldRule' => 'applications/herald/storage/rule', 'HeraldRule' => 'applications/herald/storage/rule',
'HeraldRuleController' => 'applications/herald/controller/rule', 'HeraldRuleController' => 'applications/herald/controller/rule',
'HeraldRuleEdit' => 'applications/herald/storage/edithistory',
'HeraldRuleEditHistoryController' => 'applications/herald/controller/edithistory',
'HeraldRuleEditHistoryView' => 'applications/herald/view/edithistory',
'HeraldRuleListView' => 'applications/herald/view/rulelist', 'HeraldRuleListView' => 'applications/herald/view/rulelist',
'HeraldRuleTranscript' => 'applications/herald/storage/transcript/rule', 'HeraldRuleTranscript' => 'applications/herald/storage/transcript/rule',
'HeraldRuleTypeConfig' => 'applications/herald/config/ruletype', 'HeraldRuleTypeConfig' => 'applications/herald/config/ruletype',
@ -1097,6 +1100,9 @@ phutil_register_library_map(array(
'HeraldNewController' => 'HeraldController', 'HeraldNewController' => 'HeraldController',
'HeraldRule' => 'HeraldDAO', 'HeraldRule' => 'HeraldDAO',
'HeraldRuleController' => 'HeraldController', 'HeraldRuleController' => 'HeraldController',
'HeraldRuleEdit' => 'HeraldDAO',
'HeraldRuleEditHistoryController' => 'HeraldController',
'HeraldRuleEditHistoryView' => 'AphrontView',
'HeraldRuleListView' => 'AphrontView', 'HeraldRuleListView' => 'AphrontView',
'HeraldTestConsoleController' => 'HeraldController', 'HeraldTestConsoleController' => 'HeraldController',
'HeraldTranscript' => 'HeraldDAO', 'HeraldTranscript' => 'HeraldDAO',

View file

@ -283,6 +283,7 @@ class AphrontDefaultApplicationConfiguration
), ),
'new/(?:(?P<type>[^/]+)/)?$' => 'HeraldNewController', 'new/(?:(?P<type>[^/]+)/)?$' => 'HeraldNewController',
'rule/(?:(?P<id>\d+)/)?$' => 'HeraldRuleController', 'rule/(?:(?P<id>\d+)/)?$' => 'HeraldRuleController',
'history/(?P<id>\d+)/$' => 'HeraldRuleEditHistoryController',
'delete/(?P<id>\d+)/$' => 'HeraldDeleteController', 'delete/(?P<id>\d+)/$' => 'HeraldDeleteController',
'test/$' => 'HeraldTestConsoleController', 'test/$' => 'HeraldTestConsoleController',
'all/' => array( 'all/' => array(

View file

@ -0,0 +1,55 @@
<?php
/*
* Copyright 2012 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 HeraldRuleEditHistoryController extends HeraldController {
private $id;
public function willProcessRequest(array $data) {
$this->id = $data['id'];
}
public function processRequest() {
$rule = id(new HeraldRule())->load($this->id);
if ($rule === null) {
return new Aphront404Response();
}
$edits = $rule->loadEdits();
$rule->attachEdits($edits);
$need_phids = mpull($edits, 'getEditorPHID');
$handles = id(new PhabricatorObjectHandleData($need_phids))
->loadHandles();
$list_view = id(new HeraldRuleEditHistoryView())
->setRule($rule)
->setHandles($handles)
->setUser($this->getRequest()->getUser());
return $this->buildStandardPageResponse(
$list_view->render(),
array(
'title' => 'Rule Edit History',
));
}
public function getFilter() {
return;
}
}

View file

@ -0,0 +1,18 @@
<?php
/**
* This file is automatically generated. Lint this module to rebuild it.
* @generated
*/
phutil_require_module('phabricator', 'aphront/response/404');
phutil_require_module('phabricator', 'applications/herald/controller/base');
phutil_require_module('phabricator', 'applications/herald/storage/rule');
phutil_require_module('phabricator', 'applications/herald/view/edithistory');
phutil_require_module('phabricator', 'applications/phid/handle/data');
phutil_require_module('phutil', 'utils');
phutil_require_source('HeraldRuleEditHistoryController.php');

View file

@ -63,6 +63,11 @@ class HeraldHomeController extends HeraldController {
$user->getPHID()); $user->getPHID());
} }
foreach ($rules as $rule) {
$edits = $rule->loadEdits();
$rule->attachEdits($edits);
}
$need_phids = mpull($rules, 'getAuthorPHID'); $need_phids = mpull($rules, 'getAuthorPHID');
$handles = id(new PhabricatorObjectHandleData($need_phids)) $handles = id(new PhabricatorObjectHandleData($need_phids))
->loadHandles(); ->loadHandles();
@ -72,7 +77,8 @@ class HeraldHomeController extends HeraldController {
->setHandles($handles) ->setHandles($handles)
->setMap($map) ->setMap($map)
->setAllowCreation(true) ->setAllowCreation(true)
->setView($this->view); ->setView($this->view)
->setUser($user);
$panel = $list_view->render(); $panel = $list_view->render();

View file

@ -352,6 +352,7 @@ class HeraldRuleController extends HeraldController {
$rule->save(); $rule->save();
$rule->saveConditions($conditions); $rule->saveConditions($conditions);
$rule->saveActions($actions); $rule->saveActions($actions);
$rule->saveEdit($request->getUser()->getPHID());
// $rule->saveTransaction(); // $rule->saveTransaction();
} catch (AphrontQueryDuplicateKeyException $ex) { } catch (AphrontQueryDuplicateKeyException $ex) {

View file

@ -0,0 +1,24 @@
<?php
/*
* Copyright 2012 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 HeraldRuleEdit extends HeraldDAO {
protected $editorPHID;
protected $ruleID;
}

View file

@ -0,0 +1,12 @@
<?php
/**
* This file is automatically generated. Lint this module to rebuild it.
* @generated
*/
phutil_require_module('phabricator', 'applications/herald/storage/base');
phutil_require_source('HeraldRuleEdit.php');

View file

@ -125,6 +125,36 @@ class HeraldRule extends HeraldDAO {
return $this->actions; return $this->actions;
} }
public function loadEdits() {
if (!$this->getID()) {
return array();
}
$edits = id(new HeraldRuleEdit())->loadAllWhere(
'ruleID = %d ORDER BY dateCreated DESC',
$this->getID());
return $edits;
}
public function attachEdits(array $edits) {
$this->edits = $edits;
return $this;
}
public function getEdits() {
if ($this->edits === null) {
throw new Exception("Attach edits before accessing them!");
}
return $this->edits;
}
public function saveEdit($editor_phid) {
$edit = new HeraldRuleEdit();
$edit->setRuleID($this->getID());
$edit->setEditorPHID($editor_phid);
$edit->save();
}
public function saveConditions(array $conditions) { public function saveConditions(array $conditions) {
return $this->saveChildren( return $this->saveChildren(
id(new HeraldCondition())->getTableName(), id(new HeraldCondition())->getTableName(),

View file

@ -9,6 +9,7 @@
phutil_require_module('phabricator', 'applications/herald/storage/action'); phutil_require_module('phabricator', 'applications/herald/storage/action');
phutil_require_module('phabricator', 'applications/herald/storage/base'); phutil_require_module('phabricator', 'applications/herald/storage/base');
phutil_require_module('phabricator', 'applications/herald/storage/condition'); phutil_require_module('phabricator', 'applications/herald/storage/condition');
phutil_require_module('phabricator', 'applications/herald/storage/edithistory');
phutil_require_module('phabricator', 'storage/queryfx'); phutil_require_module('phabricator', 'storage/queryfx');
phutil_require_module('phutil', 'utils'); phutil_require_module('phutil', 'utils');

View file

@ -0,0 +1,73 @@
<?php
/*
* Copyright 2012 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.
*/
final class HeraldRuleEditHistoryView extends AphrontView {
private $rule;
private $handles;
public function setRule($rule) {
$this->rule = $rule;
return $this;
}
public function setHandles(array $handles) {
$this->handles = $handles;
return $this;
}
public function setUser($user) {
$this->user = $user;
return $this;
}
public function render() {
$rows = array();
foreach ($this->rule->getEdits() as $edit) {
$editor = $this->handles[$edit->getEditorPHID()]->renderLink();
$edit_date = phabricator_datetime($edit->getDateCreated(), $this->user);
// Something useful could totally go here
$details = "";
$rows[] = array(
$editor,
$edit_date,
$details,
);
}
$rule_name = phutil_escape_html($this->rule->getName());
$table = new AphrontTableView($rows);
$table->setNoDataString(
"No edits for \"${rule_name}\"");
$table->setHeaders(
array(
'Editor',
'Edit Date',
'Details',
));
$panel = new AphrontPanelView();
$panel->setHeader("Edit History for \"${rule_name}\"");
$panel->appendChild($table);
return $panel;
}
}

View file

@ -0,0 +1,17 @@
<?php
/**
* This file is automatically generated. Lint this module to rebuild it.
* @generated
*/
phutil_require_module('phabricator', 'view/base');
phutil_require_module('phabricator', 'view/control/table');
phutil_require_module('phabricator', 'view/layout/panel');
phutil_require_module('phabricator', 'view/utils');
phutil_require_module('phutil', 'markup');
phutil_require_source('HeraldRuleEditHistoryView.php');

View file

@ -1,7 +1,7 @@
<?php <?php
/* /*
* Copyright 2011 Facebook, Inc. * Copyright 2012 Facebook, Inc.
* *
* Licensed under the Apache License, Version 2.0 (the "License"); * Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. * you may not use this file except in compliance with the License.
@ -48,8 +48,14 @@ final class HeraldRuleListView extends AphrontView {
return $this; return $this;
} }
public function setUser($user) {
$this->user = $user;
return $this;
}
public function render() { public function render() {
$rows = array(); $rows = array();
foreach ($this->rules as $rule) { foreach ($this->rules as $rule) {
$owner = $this->handles[$rule->getAuthorPHID()]->renderLink(); $owner = $this->handles[$rule->getAuthorPHID()]->renderLink();
@ -60,6 +66,22 @@ final class HeraldRuleListView extends AphrontView {
), ),
phutil_escape_html($rule->getName())); phutil_escape_html($rule->getName()));
$last_edit_date = phabricator_datetime($rule->getDateModified(),
$this->user);
$view_edits = phutil_render_tag(
'a',
array(
'href' => '/herald/history/' . $rule->getID() . '/',
),
'(View Edits)');
$last_edited = phutil_render_tag(
'span',
array(),
"Last edited on $last_edit_date ${view_edits}");
$delete = javelin_render_tag( $delete = javelin_render_tag(
'a', 'a',
array( array(
@ -73,6 +95,7 @@ final class HeraldRuleListView extends AphrontView {
$this->map[$rule->getContentType()], $this->map[$rule->getContentType()],
$owner, $owner,
$name, $name,
$last_edited,
$delete, $delete,
); );
} }
@ -88,6 +111,7 @@ final class HeraldRuleListView extends AphrontView {
'Type', 'Type',
'Owner', 'Owner',
'Rule Name', 'Rule Name',
'Last Edited',
'', '',
)); ));
$table->setColumnClasses( $table->setColumnClasses(
@ -95,6 +119,7 @@ final class HeraldRuleListView extends AphrontView {
'', '',
'', '',
'wide wrap pri', 'wide wrap pri',
'',
'action' 'action'
)); ));

View file

@ -10,6 +10,7 @@ phutil_require_module('phabricator', 'infrastructure/javelin/markup');
phutil_require_module('phabricator', 'view/base'); phutil_require_module('phabricator', 'view/base');
phutil_require_module('phabricator', 'view/control/table'); phutil_require_module('phabricator', 'view/control/table');
phutil_require_module('phabricator', 'view/layout/panel'); phutil_require_module('phabricator', 'view/layout/panel');
phutil_require_module('phabricator', 'view/utils');
phutil_require_module('phutil', 'markup'); phutil_require_module('phutil', 'markup');