mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-16 02:20:54 +01:00
(stable) Promote 2017 Week 8
This commit is contained in:
commit
c8f5fb1205
126 changed files with 1936 additions and 1304 deletions
|
@ -7,12 +7,12 @@
|
||||||
*/
|
*/
|
||||||
return array(
|
return array(
|
||||||
'names' => array(
|
'names' => array(
|
||||||
'conpherence.pkg.css' => 'a520d619',
|
'conpherence.pkg.css' => '6875302f',
|
||||||
'conpherence.pkg.js' => '6249a1cf',
|
'conpherence.pkg.js' => '6249a1cf',
|
||||||
'core.pkg.css' => '0d7ecd3b',
|
'core.pkg.css' => 'c0340df0',
|
||||||
'core.pkg.js' => '1fa7c0c5',
|
'core.pkg.js' => '1fa7c0c5',
|
||||||
'darkconsole.pkg.js' => 'e7393ebb',
|
'darkconsole.pkg.js' => 'e7393ebb',
|
||||||
'differential.pkg.css' => '4815647b',
|
'differential.pkg.css' => '90b30783',
|
||||||
'differential.pkg.js' => 'ddfeb49b',
|
'differential.pkg.js' => 'ddfeb49b',
|
||||||
'diffusion.pkg.css' => '91c5d3a6',
|
'diffusion.pkg.css' => '91c5d3a6',
|
||||||
'diffusion.pkg.js' => '84c8f8fd',
|
'diffusion.pkg.js' => '84c8f8fd',
|
||||||
|
@ -45,7 +45,7 @@ return array(
|
||||||
'rsrc/css/application/config/config-template.css' => '8f18fa41',
|
'rsrc/css/application/config/config-template.css' => '8f18fa41',
|
||||||
'rsrc/css/application/config/setup-issue.css' => 'f794cfc3',
|
'rsrc/css/application/config/setup-issue.css' => 'f794cfc3',
|
||||||
'rsrc/css/application/config/unhandled-exception.css' => '4c96257a',
|
'rsrc/css/application/config/unhandled-exception.css' => '4c96257a',
|
||||||
'rsrc/css/application/conpherence/durable-column.css' => 'd82e130c',
|
'rsrc/css/application/conpherence/durable-column.css' => '292c71f0',
|
||||||
'rsrc/css/application/conpherence/header-pane.css' => 'db93ebc6',
|
'rsrc/css/application/conpherence/header-pane.css' => 'db93ebc6',
|
||||||
'rsrc/css/application/conpherence/menu.css' => '3d8e5c9c',
|
'rsrc/css/application/conpherence/menu.css' => '3d8e5c9c',
|
||||||
'rsrc/css/application/conpherence/message-pane.css' => 'b085d40d',
|
'rsrc/css/application/conpherence/message-pane.css' => 'b085d40d',
|
||||||
|
@ -58,7 +58,7 @@ return array(
|
||||||
'rsrc/css/application/dashboard/dashboard.css' => '0921c307',
|
'rsrc/css/application/dashboard/dashboard.css' => '0921c307',
|
||||||
'rsrc/css/application/diff/inline-comment-summary.css' => '51efda3a',
|
'rsrc/css/application/diff/inline-comment-summary.css' => '51efda3a',
|
||||||
'rsrc/css/application/differential/add-comment.css' => 'c47f8c40',
|
'rsrc/css/application/differential/add-comment.css' => 'c47f8c40',
|
||||||
'rsrc/css/application/differential/changeset-view.css' => '6a9bdf9c',
|
'rsrc/css/application/differential/changeset-view.css' => '41af6d25',
|
||||||
'rsrc/css/application/differential/core.css' => '5b7b8ff4',
|
'rsrc/css/application/differential/core.css' => '5b7b8ff4',
|
||||||
'rsrc/css/application/differential/phui-inline-comment.css' => 'be663c95',
|
'rsrc/css/application/differential/phui-inline-comment.css' => 'be663c95',
|
||||||
'rsrc/css/application/differential/revision-comment.css' => '14b8565a',
|
'rsrc/css/application/differential/revision-comment.css' => '14b8565a',
|
||||||
|
@ -96,8 +96,8 @@ return array(
|
||||||
'rsrc/css/application/policy/policy-transaction-detail.css' => '82100a43',
|
'rsrc/css/application/policy/policy-transaction-detail.css' => '82100a43',
|
||||||
'rsrc/css/application/policy/policy.css' => '957ea14c',
|
'rsrc/css/application/policy/policy.css' => '957ea14c',
|
||||||
'rsrc/css/application/ponder/ponder-view.css' => 'fbd45f96',
|
'rsrc/css/application/ponder/ponder-view.css' => 'fbd45f96',
|
||||||
'rsrc/css/application/project/project-card-view.css' => 'f25746f5',
|
'rsrc/css/application/project/project-card-view.css' => '77219296',
|
||||||
'rsrc/css/application/project/project-view.css' => '9f6ce0e1',
|
'rsrc/css/application/project/project-view.css' => '792c9057',
|
||||||
'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733',
|
'rsrc/css/application/releeph/releeph-core.css' => '9b3c5733',
|
||||||
'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5',
|
'rsrc/css/application/releeph/releeph-preview-branch.css' => 'b7a6f4a5',
|
||||||
'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd',
|
'rsrc/css/application/releeph/releeph-request-differential-create-dialog.css' => '8d8b92cd',
|
||||||
|
@ -130,7 +130,7 @@ return array(
|
||||||
'rsrc/css/phui/object-item/phui-oi-simple-ui.css' => 'a8beebea',
|
'rsrc/css/phui/object-item/phui-oi-simple-ui.css' => 'a8beebea',
|
||||||
'rsrc/css/phui/phui-action-list.css' => 'f980c059',
|
'rsrc/css/phui/phui-action-list.css' => 'f980c059',
|
||||||
'rsrc/css/phui/phui-action-panel.css' => '91c7b835',
|
'rsrc/css/phui/phui-action-panel.css' => '91c7b835',
|
||||||
'rsrc/css/phui/phui-badge.css' => '3baef8db',
|
'rsrc/css/phui/phui-badge.css' => '22c0cf4f',
|
||||||
'rsrc/css/phui/phui-basic-nav-view.css' => 'a0705f53',
|
'rsrc/css/phui/phui-basic-nav-view.css' => 'a0705f53',
|
||||||
'rsrc/css/phui/phui-big-info-view.css' => 'bd903741',
|
'rsrc/css/phui/phui-big-info-view.css' => 'bd903741',
|
||||||
'rsrc/css/phui/phui-box.css' => '269cbc99',
|
'rsrc/css/phui/phui-box.css' => '269cbc99',
|
||||||
|
@ -150,9 +150,9 @@ return array(
|
||||||
'rsrc/css/phui/phui-form.css' => '5815af7b',
|
'rsrc/css/phui/phui-form.css' => '5815af7b',
|
||||||
'rsrc/css/phui/phui-head-thing.css' => 'fd311e5f',
|
'rsrc/css/phui/phui-head-thing.css' => 'fd311e5f',
|
||||||
'rsrc/css/phui/phui-header-view.css' => 'fef6a54e',
|
'rsrc/css/phui/phui-header-view.css' => 'fef6a54e',
|
||||||
'rsrc/css/phui/phui-hovercard.css' => 'e904f5dc',
|
'rsrc/css/phui/phui-hovercard.css' => 'ae091fc5',
|
||||||
'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee',
|
'rsrc/css/phui/phui-icon-set-selector.css' => '87db8fee',
|
||||||
'rsrc/css/phui/phui-icon.css' => '09f46dd9',
|
'rsrc/css/phui/phui-icon.css' => '12b387a1',
|
||||||
'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c',
|
'rsrc/css/phui/phui-image-mask.css' => 'a8498f9c',
|
||||||
'rsrc/css/phui/phui-info-panel.css' => '27ea50a1',
|
'rsrc/css/phui/phui-info-panel.css' => '27ea50a1',
|
||||||
'rsrc/css/phui/phui-info-view.css' => 'ec92802a',
|
'rsrc/css/phui/phui-info-view.css' => 'ec92802a',
|
||||||
|
@ -160,7 +160,7 @@ return array(
|
||||||
'rsrc/css/phui/phui-lightbox.css' => '0a035e40',
|
'rsrc/css/phui/phui-lightbox.css' => '0a035e40',
|
||||||
'rsrc/css/phui/phui-list.css' => '9da2aa00',
|
'rsrc/css/phui/phui-list.css' => '9da2aa00',
|
||||||
'rsrc/css/phui/phui-object-box.css' => '8b289e3d',
|
'rsrc/css/phui/phui-object-box.css' => '8b289e3d',
|
||||||
'rsrc/css/phui/phui-pager.css' => 'bea33d23',
|
'rsrc/css/phui/phui-pager.css' => '77d8a794',
|
||||||
'rsrc/css/phui/phui-pinboard-view.css' => '2495140e',
|
'rsrc/css/phui/phui-pinboard-view.css' => '2495140e',
|
||||||
'rsrc/css/phui/phui-property-list-view.css' => '2dc7993f',
|
'rsrc/css/phui/phui-property-list-view.css' => '2dc7993f',
|
||||||
'rsrc/css/phui/phui-remarkup-preview.css' => '1a8f2591',
|
'rsrc/css/phui/phui-remarkup-preview.css' => '1a8f2591',
|
||||||
|
@ -168,7 +168,7 @@ return array(
|
||||||
'rsrc/css/phui/phui-spacing.css' => '042804d6',
|
'rsrc/css/phui/phui-spacing.css' => '042804d6',
|
||||||
'rsrc/css/phui/phui-status.css' => 'd5263e49',
|
'rsrc/css/phui/phui-status.css' => 'd5263e49',
|
||||||
'rsrc/css/phui/phui-tag-view.css' => '84d65f26',
|
'rsrc/css/phui/phui-tag-view.css' => '84d65f26',
|
||||||
'rsrc/css/phui/phui-timeline-view.css' => 'bc523970',
|
'rsrc/css/phui/phui-timeline-view.css' => 'bf45789e',
|
||||||
'rsrc/css/phui/phui-two-column-view.css' => '8a1074c7',
|
'rsrc/css/phui/phui-two-column-view.css' => '8a1074c7',
|
||||||
'rsrc/css/phui/workboards/phui-workboard-color.css' => '783cdff5',
|
'rsrc/css/phui/workboards/phui-workboard-color.css' => '783cdff5',
|
||||||
'rsrc/css/phui/workboards/phui-workboard.css' => '3bc85455',
|
'rsrc/css/phui/workboards/phui-workboard.css' => '3bc85455',
|
||||||
|
@ -376,7 +376,7 @@ return array(
|
||||||
'rsrc/js/application/aphlict/behavior-aphlict-dropdown.js' => 'caade6f2',
|
'rsrc/js/application/aphlict/behavior-aphlict-dropdown.js' => 'caade6f2',
|
||||||
'rsrc/js/application/aphlict/behavior-aphlict-listen.js' => 'fb20ac8d',
|
'rsrc/js/application/aphlict/behavior-aphlict-listen.js' => 'fb20ac8d',
|
||||||
'rsrc/js/application/aphlict/behavior-aphlict-status.js' => '5e2634b9',
|
'rsrc/js/application/aphlict/behavior-aphlict-status.js' => '5e2634b9',
|
||||||
'rsrc/js/application/aphlict/behavior-desktop-notifications-control.js' => 'edd1ba66',
|
'rsrc/js/application/aphlict/behavior-desktop-notifications-control.js' => 'd5a2d665',
|
||||||
'rsrc/js/application/calendar/behavior-day-view.js' => '4b3c4443',
|
'rsrc/js/application/calendar/behavior-day-view.js' => '4b3c4443',
|
||||||
'rsrc/js/application/calendar/behavior-event-all-day.js' => 'b41537c9',
|
'rsrc/js/application/calendar/behavior-event-all-day.js' => 'b41537c9',
|
||||||
'rsrc/js/application/calendar/behavior-month-view.js' => 'fe33e256',
|
'rsrc/js/application/calendar/behavior-month-view.js' => 'fe33e256',
|
||||||
|
@ -563,7 +563,7 @@ return array(
|
||||||
'conduit-api-css' => '7bc725c4',
|
'conduit-api-css' => '7bc725c4',
|
||||||
'config-options-css' => '0ede4c9b',
|
'config-options-css' => '0ede4c9b',
|
||||||
'config-page-css' => 'c1d5121b',
|
'config-page-css' => 'c1d5121b',
|
||||||
'conpherence-durable-column-view' => 'd82e130c',
|
'conpherence-durable-column-view' => '292c71f0',
|
||||||
'conpherence-header-pane-css' => 'db93ebc6',
|
'conpherence-header-pane-css' => 'db93ebc6',
|
||||||
'conpherence-menu-css' => '3d8e5c9c',
|
'conpherence-menu-css' => '3d8e5c9c',
|
||||||
'conpherence-message-pane-css' => 'b085d40d',
|
'conpherence-message-pane-css' => 'b085d40d',
|
||||||
|
@ -572,7 +572,7 @@ return array(
|
||||||
'conpherence-thread-manager' => 'c8b5ee6f',
|
'conpherence-thread-manager' => 'c8b5ee6f',
|
||||||
'conpherence-transaction-css' => '85129c68',
|
'conpherence-transaction-css' => '85129c68',
|
||||||
'd3' => 'a11a5ff2',
|
'd3' => 'a11a5ff2',
|
||||||
'differential-changeset-view-css' => '6a9bdf9c',
|
'differential-changeset-view-css' => '41af6d25',
|
||||||
'differential-core-view-css' => '5b7b8ff4',
|
'differential-core-view-css' => '5b7b8ff4',
|
||||||
'differential-inline-comment-editor' => '2e3f9738',
|
'differential-inline-comment-editor' => '2e3f9738',
|
||||||
'differential-revision-add-comment-css' => 'c47f8c40',
|
'differential-revision-add-comment-css' => 'c47f8c40',
|
||||||
|
@ -621,7 +621,7 @@ return array(
|
||||||
'javelin-behavior-dashboard-query-panel-select' => '453c5375',
|
'javelin-behavior-dashboard-query-panel-select' => '453c5375',
|
||||||
'javelin-behavior-dashboard-tab-panel' => 'd4eecc63',
|
'javelin-behavior-dashboard-tab-panel' => 'd4eecc63',
|
||||||
'javelin-behavior-day-view' => '4b3c4443',
|
'javelin-behavior-day-view' => '4b3c4443',
|
||||||
'javelin-behavior-desktop-notifications-control' => 'edd1ba66',
|
'javelin-behavior-desktop-notifications-control' => 'd5a2d665',
|
||||||
'javelin-behavior-detect-timezone' => '4c193c96',
|
'javelin-behavior-detect-timezone' => '4c193c96',
|
||||||
'javelin-behavior-device' => 'bb1dd507',
|
'javelin-behavior-device' => 'bb1dd507',
|
||||||
'javelin-behavior-diff-preview-link' => '051c7832',
|
'javelin-behavior-diff-preview-link' => '051c7832',
|
||||||
|
@ -837,7 +837,7 @@ return array(
|
||||||
'phrequent-css' => 'ffc185ad',
|
'phrequent-css' => 'ffc185ad',
|
||||||
'phriction-document-css' => '4282e4ad',
|
'phriction-document-css' => '4282e4ad',
|
||||||
'phui-action-panel-css' => '91c7b835',
|
'phui-action-panel-css' => '91c7b835',
|
||||||
'phui-badge-view-css' => '3baef8db',
|
'phui-badge-view-css' => '22c0cf4f',
|
||||||
'phui-basic-nav-view-css' => 'a0705f53',
|
'phui-basic-nav-view-css' => 'a0705f53',
|
||||||
'phui-big-info-view-css' => 'bd903741',
|
'phui-big-info-view-css' => 'bd903741',
|
||||||
'phui-box-css' => '269cbc99',
|
'phui-box-css' => '269cbc99',
|
||||||
|
@ -863,9 +863,9 @@ return array(
|
||||||
'phui-head-thing-view-css' => 'fd311e5f',
|
'phui-head-thing-view-css' => 'fd311e5f',
|
||||||
'phui-header-view-css' => 'fef6a54e',
|
'phui-header-view-css' => 'fef6a54e',
|
||||||
'phui-hovercard' => '1bd28176',
|
'phui-hovercard' => '1bd28176',
|
||||||
'phui-hovercard-view-css' => 'e904f5dc',
|
'phui-hovercard-view-css' => 'ae091fc5',
|
||||||
'phui-icon-set-selector-css' => '87db8fee',
|
'phui-icon-set-selector-css' => '87db8fee',
|
||||||
'phui-icon-view-css' => '09f46dd9',
|
'phui-icon-view-css' => '12b387a1',
|
||||||
'phui-image-mask-css' => 'a8498f9c',
|
'phui-image-mask-css' => 'a8498f9c',
|
||||||
'phui-info-panel-css' => '27ea50a1',
|
'phui-info-panel-css' => '27ea50a1',
|
||||||
'phui-info-view-css' => 'ec92802a',
|
'phui-info-view-css' => 'ec92802a',
|
||||||
|
@ -880,7 +880,7 @@ return array(
|
||||||
'phui-oi-flush-ui-css' => '9d9685d6',
|
'phui-oi-flush-ui-css' => '9d9685d6',
|
||||||
'phui-oi-list-view-css' => '5c383524',
|
'phui-oi-list-view-css' => '5c383524',
|
||||||
'phui-oi-simple-ui-css' => 'a8beebea',
|
'phui-oi-simple-ui-css' => 'a8beebea',
|
||||||
'phui-pager-css' => 'bea33d23',
|
'phui-pager-css' => '77d8a794',
|
||||||
'phui-pinboard-view-css' => '2495140e',
|
'phui-pinboard-view-css' => '2495140e',
|
||||||
'phui-property-list-view-css' => '2dc7993f',
|
'phui-property-list-view-css' => '2dc7993f',
|
||||||
'phui-remarkup-preview-css' => '1a8f2591',
|
'phui-remarkup-preview-css' => '1a8f2591',
|
||||||
|
@ -889,7 +889,7 @@ return array(
|
||||||
'phui-status-list-view-css' => 'd5263e49',
|
'phui-status-list-view-css' => 'd5263e49',
|
||||||
'phui-tag-view-css' => '84d65f26',
|
'phui-tag-view-css' => '84d65f26',
|
||||||
'phui-theme-css' => '9f261c6b',
|
'phui-theme-css' => '9f261c6b',
|
||||||
'phui-timeline-view-css' => 'bc523970',
|
'phui-timeline-view-css' => 'bf45789e',
|
||||||
'phui-two-column-view-css' => '8a1074c7',
|
'phui-two-column-view-css' => '8a1074c7',
|
||||||
'phui-workboard-color-css' => '783cdff5',
|
'phui-workboard-color-css' => '783cdff5',
|
||||||
'phui-workboard-view-css' => '3bc85455',
|
'phui-workboard-view-css' => '3bc85455',
|
||||||
|
@ -905,8 +905,8 @@ return array(
|
||||||
'policy-edit-css' => '815c66f7',
|
'policy-edit-css' => '815c66f7',
|
||||||
'policy-transaction-detail-css' => '82100a43',
|
'policy-transaction-detail-css' => '82100a43',
|
||||||
'ponder-view-css' => 'fbd45f96',
|
'ponder-view-css' => 'fbd45f96',
|
||||||
'project-card-view-css' => 'f25746f5',
|
'project-card-view-css' => '77219296',
|
||||||
'project-view-css' => '9f6ce0e1',
|
'project-view-css' => '792c9057',
|
||||||
'releeph-core' => '9b3c5733',
|
'releeph-core' => '9b3c5733',
|
||||||
'releeph-preview-branch' => 'b7a6f4a5',
|
'releeph-preview-branch' => 'b7a6f4a5',
|
||||||
'releeph-request-differential-create-dialog' => '8d8b92cd',
|
'releeph-request-differential-create-dialog' => '8d8b92cd',
|
||||||
|
@ -1166,6 +1166,9 @@ return array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
'javelin-reactor-dom',
|
'javelin-reactor-dom',
|
||||||
),
|
),
|
||||||
|
'41af6d25' => array(
|
||||||
|
'phui-inline-comment-view-css',
|
||||||
|
),
|
||||||
42126667 => array(
|
42126667 => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
|
@ -1386,9 +1389,6 @@ return array(
|
||||||
'69adf288' => array(
|
'69adf288' => array(
|
||||||
'javelin-install',
|
'javelin-install',
|
||||||
),
|
),
|
||||||
'6a9bdf9c' => array(
|
|
||||||
'phui-inline-comment-view-css',
|
|
||||||
),
|
|
||||||
'6ad39b6f' => array(
|
'6ad39b6f' => array(
|
||||||
'javelin-install',
|
'javelin-install',
|
||||||
'javelin-event',
|
'javelin-event',
|
||||||
|
@ -2060,6 +2060,13 @@ return array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
'javelin-stratcom',
|
'javelin-stratcom',
|
||||||
),
|
),
|
||||||
|
'd5a2d665' => array(
|
||||||
|
'javelin-behavior',
|
||||||
|
'javelin-stratcom',
|
||||||
|
'javelin-dom',
|
||||||
|
'javelin-uri',
|
||||||
|
'phabricator-notification',
|
||||||
|
),
|
||||||
'd6a7e717' => array(
|
'd6a7e717' => array(
|
||||||
'multirow-row-manager',
|
'multirow-row-manager',
|
||||||
'javelin-install',
|
'javelin-install',
|
||||||
|
@ -2154,13 +2161,6 @@ return array(
|
||||||
'javelin-dom',
|
'javelin-dom',
|
||||||
'phabricator-draggable-list',
|
'phabricator-draggable-list',
|
||||||
),
|
),
|
||||||
'edd1ba66' => array(
|
|
||||||
'javelin-behavior',
|
|
||||||
'javelin-stratcom',
|
|
||||||
'javelin-dom',
|
|
||||||
'javelin-uri',
|
|
||||||
'phabricator-notification',
|
|
||||||
),
|
|
||||||
'edf8a145' => array(
|
'edf8a145' => array(
|
||||||
'javelin-behavior',
|
'javelin-behavior',
|
||||||
'javelin-uri',
|
'javelin-uri',
|
||||||
|
|
|
@ -235,6 +235,7 @@ phutil_register_library_map(array(
|
||||||
'CelerityPhysicalResourcesTestCase' => 'applications/celerity/resources/__tests__/CelerityPhysicalResourcesTestCase.php',
|
'CelerityPhysicalResourcesTestCase' => 'applications/celerity/resources/__tests__/CelerityPhysicalResourcesTestCase.php',
|
||||||
'CelerityPostprocessor' => 'applications/celerity/postprocessor/CelerityPostprocessor.php',
|
'CelerityPostprocessor' => 'applications/celerity/postprocessor/CelerityPostprocessor.php',
|
||||||
'CelerityPostprocessorTestCase' => 'applications/celerity/__tests__/CelerityPostprocessorTestCase.php',
|
'CelerityPostprocessorTestCase' => 'applications/celerity/__tests__/CelerityPostprocessorTestCase.php',
|
||||||
|
'CelerityRedGreenPostprocessor' => 'applications/celerity/postprocessor/CelerityRedGreenPostprocessor.php',
|
||||||
'CelerityResourceController' => 'applications/celerity/controller/CelerityResourceController.php',
|
'CelerityResourceController' => 'applications/celerity/controller/CelerityResourceController.php',
|
||||||
'CelerityResourceGraph' => 'applications/celerity/CelerityResourceGraph.php',
|
'CelerityResourceGraph' => 'applications/celerity/CelerityResourceGraph.php',
|
||||||
'CelerityResourceMap' => 'applications/celerity/CelerityResourceMap.php',
|
'CelerityResourceMap' => 'applications/celerity/CelerityResourceMap.php',
|
||||||
|
@ -2011,7 +2012,16 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorBadgesAwardController' => 'applications/badges/controller/PhabricatorBadgesAwardController.php',
|
'PhabricatorBadgesAwardController' => 'applications/badges/controller/PhabricatorBadgesAwardController.php',
|
||||||
'PhabricatorBadgesAwardQuery' => 'applications/badges/query/PhabricatorBadgesAwardQuery.php',
|
'PhabricatorBadgesAwardQuery' => 'applications/badges/query/PhabricatorBadgesAwardQuery.php',
|
||||||
'PhabricatorBadgesBadge' => 'applications/badges/storage/PhabricatorBadgesBadge.php',
|
'PhabricatorBadgesBadge' => 'applications/badges/storage/PhabricatorBadgesBadge.php',
|
||||||
|
'PhabricatorBadgesBadgeAwardTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeAwardTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeDescriptionTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeDescriptionTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeFlavorTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeFlavorTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeIconTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeIconTransaction.php',
|
||||||
'PhabricatorBadgesBadgeNameNgrams' => 'applications/badges/storage/PhabricatorBadgesBadgeNameNgrams.php',
|
'PhabricatorBadgesBadgeNameNgrams' => 'applications/badges/storage/PhabricatorBadgesBadgeNameNgrams.php',
|
||||||
|
'PhabricatorBadgesBadgeNameTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeNameTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeQualityTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeQualityTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeRevokeTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeRevokeTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeStatusTransaction' => 'applications/badges/xaction/PhabricatorBadgesBadgeStatusTransaction.php',
|
||||||
|
'PhabricatorBadgesBadgeTransactionType' => 'applications/badges/xaction/PhabricatorBadgesBadgeTransactionType.php',
|
||||||
'PhabricatorBadgesCommentController' => 'applications/badges/controller/PhabricatorBadgesCommentController.php',
|
'PhabricatorBadgesCommentController' => 'applications/badges/controller/PhabricatorBadgesCommentController.php',
|
||||||
'PhabricatorBadgesController' => 'applications/badges/controller/PhabricatorBadgesController.php',
|
'PhabricatorBadgesController' => 'applications/badges/controller/PhabricatorBadgesController.php',
|
||||||
'PhabricatorBadgesCreateCapability' => 'applications/badges/capability/PhabricatorBadgesCreateCapability.php',
|
'PhabricatorBadgesCreateCapability' => 'applications/badges/capability/PhabricatorBadgesCreateCapability.php',
|
||||||
|
@ -3306,6 +3316,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleAnyOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleAnyOwnerDatasource.php',
|
'PhabricatorPeopleAnyOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleAnyOwnerDatasource.php',
|
||||||
'PhabricatorPeopleApplication' => 'applications/people/application/PhabricatorPeopleApplication.php',
|
'PhabricatorPeopleApplication' => 'applications/people/application/PhabricatorPeopleApplication.php',
|
||||||
'PhabricatorPeopleApproveController' => 'applications/people/controller/PhabricatorPeopleApproveController.php',
|
'PhabricatorPeopleApproveController' => 'applications/people/controller/PhabricatorPeopleApproveController.php',
|
||||||
|
'PhabricatorPeopleBadgesProfileMenuItem' => 'applications/people/menuitem/PhabricatorPeopleBadgesProfileMenuItem.php',
|
||||||
'PhabricatorPeopleController' => 'applications/people/controller/PhabricatorPeopleController.php',
|
'PhabricatorPeopleController' => 'applications/people/controller/PhabricatorPeopleController.php',
|
||||||
'PhabricatorPeopleCreateController' => 'applications/people/controller/PhabricatorPeopleCreateController.php',
|
'PhabricatorPeopleCreateController' => 'applications/people/controller/PhabricatorPeopleCreateController.php',
|
||||||
'PhabricatorPeopleCreateGuidanceContext' => 'applications/people/guidance/PhabricatorPeopleCreateGuidanceContext.php',
|
'PhabricatorPeopleCreateGuidanceContext' => 'applications/people/guidance/PhabricatorPeopleCreateGuidanceContext.php',
|
||||||
|
@ -3329,6 +3340,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleNoOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleNoOwnerDatasource.php',
|
'PhabricatorPeopleNoOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleNoOwnerDatasource.php',
|
||||||
'PhabricatorPeopleOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleOwnerDatasource.php',
|
'PhabricatorPeopleOwnerDatasource' => 'applications/people/typeahead/PhabricatorPeopleOwnerDatasource.php',
|
||||||
'PhabricatorPeoplePictureProfileMenuItem' => 'applications/people/menuitem/PhabricatorPeoplePictureProfileMenuItem.php',
|
'PhabricatorPeoplePictureProfileMenuItem' => 'applications/people/menuitem/PhabricatorPeoplePictureProfileMenuItem.php',
|
||||||
|
'PhabricatorPeopleProfileBadgesController' => 'applications/people/controller/PhabricatorPeopleProfileBadgesController.php',
|
||||||
'PhabricatorPeopleProfileController' => 'applications/people/controller/PhabricatorPeopleProfileController.php',
|
'PhabricatorPeopleProfileController' => 'applications/people/controller/PhabricatorPeopleProfileController.php',
|
||||||
'PhabricatorPeopleProfileEditController' => 'applications/people/controller/PhabricatorPeopleProfileEditController.php',
|
'PhabricatorPeopleProfileEditController' => 'applications/people/controller/PhabricatorPeopleProfileEditController.php',
|
||||||
'PhabricatorPeopleProfileManageController' => 'applications/people/controller/PhabricatorPeopleProfileManageController.php',
|
'PhabricatorPeopleProfileManageController' => 'applications/people/controller/PhabricatorPeopleProfileManageController.php',
|
||||||
|
@ -3370,16 +3382,20 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPhurlShortURLDefaultController' => 'applications/phurl/controller/PhabricatorPhurlShortURLDefaultController.php',
|
'PhabricatorPhurlShortURLDefaultController' => 'applications/phurl/controller/PhabricatorPhurlShortURLDefaultController.php',
|
||||||
'PhabricatorPhurlURL' => 'applications/phurl/storage/PhabricatorPhurlURL.php',
|
'PhabricatorPhurlURL' => 'applications/phurl/storage/PhabricatorPhurlURL.php',
|
||||||
'PhabricatorPhurlURLAccessController' => 'applications/phurl/controller/PhabricatorPhurlURLAccessController.php',
|
'PhabricatorPhurlURLAccessController' => 'applications/phurl/controller/PhabricatorPhurlURLAccessController.php',
|
||||||
|
'PhabricatorPhurlURLAliasTransaction' => 'applications/phurl/xaction/PhabricatorPhurlURLAliasTransaction.php',
|
||||||
'PhabricatorPhurlURLCommentController' => 'applications/phurl/controller/PhabricatorPhurlURLCommentController.php',
|
'PhabricatorPhurlURLCommentController' => 'applications/phurl/controller/PhabricatorPhurlURLCommentController.php',
|
||||||
'PhabricatorPhurlURLCreateCapability' => 'applications/phurl/capability/PhabricatorPhurlURLCreateCapability.php',
|
'PhabricatorPhurlURLCreateCapability' => 'applications/phurl/capability/PhabricatorPhurlURLCreateCapability.php',
|
||||||
'PhabricatorPhurlURLDatasource' => 'applications/phurl/typeahead/PhabricatorPhurlURLDatasource.php',
|
'PhabricatorPhurlURLDatasource' => 'applications/phurl/typeahead/PhabricatorPhurlURLDatasource.php',
|
||||||
|
'PhabricatorPhurlURLDescriptionTransaction' => 'applications/phurl/xaction/PhabricatorPhurlURLDescriptionTransaction.php',
|
||||||
'PhabricatorPhurlURLEditConduitAPIMethod' => 'applications/phurl/conduit/PhabricatorPhurlURLEditConduitAPIMethod.php',
|
'PhabricatorPhurlURLEditConduitAPIMethod' => 'applications/phurl/conduit/PhabricatorPhurlURLEditConduitAPIMethod.php',
|
||||||
'PhabricatorPhurlURLEditController' => 'applications/phurl/controller/PhabricatorPhurlURLEditController.php',
|
'PhabricatorPhurlURLEditController' => 'applications/phurl/controller/PhabricatorPhurlURLEditController.php',
|
||||||
'PhabricatorPhurlURLEditEngine' => 'applications/phurl/editor/PhabricatorPhurlURLEditEngine.php',
|
'PhabricatorPhurlURLEditEngine' => 'applications/phurl/editor/PhabricatorPhurlURLEditEngine.php',
|
||||||
'PhabricatorPhurlURLEditor' => 'applications/phurl/editor/PhabricatorPhurlURLEditor.php',
|
'PhabricatorPhurlURLEditor' => 'applications/phurl/editor/PhabricatorPhurlURLEditor.php',
|
||||||
'PhabricatorPhurlURLListController' => 'applications/phurl/controller/PhabricatorPhurlURLListController.php',
|
'PhabricatorPhurlURLListController' => 'applications/phurl/controller/PhabricatorPhurlURLListController.php',
|
||||||
|
'PhabricatorPhurlURLLongURLTransaction' => 'applications/phurl/xaction/PhabricatorPhurlURLLongURLTransaction.php',
|
||||||
'PhabricatorPhurlURLMailReceiver' => 'applications/phurl/mail/PhabricatorPhurlURLMailReceiver.php',
|
'PhabricatorPhurlURLMailReceiver' => 'applications/phurl/mail/PhabricatorPhurlURLMailReceiver.php',
|
||||||
'PhabricatorPhurlURLNameNgrams' => 'applications/phurl/storage/PhabricatorPhurlURLNameNgrams.php',
|
'PhabricatorPhurlURLNameNgrams' => 'applications/phurl/storage/PhabricatorPhurlURLNameNgrams.php',
|
||||||
|
'PhabricatorPhurlURLNameTransaction' => 'applications/phurl/xaction/PhabricatorPhurlURLNameTransaction.php',
|
||||||
'PhabricatorPhurlURLPHIDType' => 'applications/phurl/phid/PhabricatorPhurlURLPHIDType.php',
|
'PhabricatorPhurlURLPHIDType' => 'applications/phurl/phid/PhabricatorPhurlURLPHIDType.php',
|
||||||
'PhabricatorPhurlURLQuery' => 'applications/phurl/query/PhabricatorPhurlURLQuery.php',
|
'PhabricatorPhurlURLQuery' => 'applications/phurl/query/PhabricatorPhurlURLQuery.php',
|
||||||
'PhabricatorPhurlURLReplyHandler' => 'applications/phurl/mail/PhabricatorPhurlURLReplyHandler.php',
|
'PhabricatorPhurlURLReplyHandler' => 'applications/phurl/mail/PhabricatorPhurlURLReplyHandler.php',
|
||||||
|
@ -3388,6 +3404,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPhurlURLTransaction' => 'applications/phurl/storage/PhabricatorPhurlURLTransaction.php',
|
'PhabricatorPhurlURLTransaction' => 'applications/phurl/storage/PhabricatorPhurlURLTransaction.php',
|
||||||
'PhabricatorPhurlURLTransactionComment' => 'applications/phurl/storage/PhabricatorPhurlURLTransactionComment.php',
|
'PhabricatorPhurlURLTransactionComment' => 'applications/phurl/storage/PhabricatorPhurlURLTransactionComment.php',
|
||||||
'PhabricatorPhurlURLTransactionQuery' => 'applications/phurl/query/PhabricatorPhurlURLTransactionQuery.php',
|
'PhabricatorPhurlURLTransactionQuery' => 'applications/phurl/query/PhabricatorPhurlURLTransactionQuery.php',
|
||||||
|
'PhabricatorPhurlURLTransactionType' => 'applications/phurl/xaction/PhabricatorPhurlURLTransactionType.php',
|
||||||
'PhabricatorPhurlURLViewController' => 'applications/phurl/controller/PhabricatorPhurlURLViewController.php',
|
'PhabricatorPhurlURLViewController' => 'applications/phurl/controller/PhabricatorPhurlURLViewController.php',
|
||||||
'PhabricatorPinnedApplicationsSetting' => 'applications/settings/setting/PhabricatorPinnedApplicationsSetting.php',
|
'PhabricatorPinnedApplicationsSetting' => 'applications/settings/setting/PhabricatorPinnedApplicationsSetting.php',
|
||||||
'PhabricatorPirateEnglishTranslation' => 'infrastructure/internationalization/translation/PhabricatorPirateEnglishTranslation.php',
|
'PhabricatorPirateEnglishTranslation' => 'infrastructure/internationalization/translation/PhabricatorPirateEnglishTranslation.php',
|
||||||
|
@ -4125,12 +4142,15 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorXHProfApplication' => 'applications/xhprof/application/PhabricatorXHProfApplication.php',
|
'PhabricatorXHProfApplication' => 'applications/xhprof/application/PhabricatorXHProfApplication.php',
|
||||||
'PhabricatorXHProfController' => 'applications/xhprof/controller/PhabricatorXHProfController.php',
|
'PhabricatorXHProfController' => 'applications/xhprof/controller/PhabricatorXHProfController.php',
|
||||||
'PhabricatorXHProfDAO' => 'applications/xhprof/storage/PhabricatorXHProfDAO.php',
|
'PhabricatorXHProfDAO' => 'applications/xhprof/storage/PhabricatorXHProfDAO.php',
|
||||||
|
'PhabricatorXHProfDropController' => 'applications/xhprof/controller/PhabricatorXHProfDropController.php',
|
||||||
'PhabricatorXHProfProfileController' => 'applications/xhprof/controller/PhabricatorXHProfProfileController.php',
|
'PhabricatorXHProfProfileController' => 'applications/xhprof/controller/PhabricatorXHProfProfileController.php',
|
||||||
'PhabricatorXHProfProfileSymbolView' => 'applications/xhprof/view/PhabricatorXHProfProfileSymbolView.php',
|
'PhabricatorXHProfProfileSymbolView' => 'applications/xhprof/view/PhabricatorXHProfProfileSymbolView.php',
|
||||||
'PhabricatorXHProfProfileTopLevelView' => 'applications/xhprof/view/PhabricatorXHProfProfileTopLevelView.php',
|
'PhabricatorXHProfProfileTopLevelView' => 'applications/xhprof/view/PhabricatorXHProfProfileTopLevelView.php',
|
||||||
'PhabricatorXHProfProfileView' => 'applications/xhprof/view/PhabricatorXHProfProfileView.php',
|
'PhabricatorXHProfProfileView' => 'applications/xhprof/view/PhabricatorXHProfProfileView.php',
|
||||||
'PhabricatorXHProfSample' => 'applications/xhprof/storage/PhabricatorXHProfSample.php',
|
'PhabricatorXHProfSample' => 'applications/xhprof/storage/PhabricatorXHProfSample.php',
|
||||||
'PhabricatorXHProfSampleListController' => 'applications/xhprof/controller/PhabricatorXHProfSampleListController.php',
|
'PhabricatorXHProfSampleListController' => 'applications/xhprof/controller/PhabricatorXHProfSampleListController.php',
|
||||||
|
'PhabricatorXHProfSampleQuery' => 'applications/xhprof/query/PhabricatorXHProfSampleQuery.php',
|
||||||
|
'PhabricatorXHProfSampleSearchEngine' => 'applications/xhprof/query/PhabricatorXHProfSampleSearchEngine.php',
|
||||||
'PhabricatorYoutubeRemarkupRule' => 'infrastructure/markup/rule/PhabricatorYoutubeRemarkupRule.php',
|
'PhabricatorYoutubeRemarkupRule' => 'infrastructure/markup/rule/PhabricatorYoutubeRemarkupRule.php',
|
||||||
'Phame404Response' => 'applications/phame/site/Phame404Response.php',
|
'Phame404Response' => 'applications/phame/site/Phame404Response.php',
|
||||||
'PhameBlog' => 'applications/phame/storage/PhameBlog.php',
|
'PhameBlog' => 'applications/phame/storage/PhameBlog.php',
|
||||||
|
@ -4911,6 +4931,7 @@ phutil_register_library_map(array(
|
||||||
'CelerityPhysicalResourcesTestCase' => 'PhabricatorTestCase',
|
'CelerityPhysicalResourcesTestCase' => 'PhabricatorTestCase',
|
||||||
'CelerityPostprocessor' => 'Phobject',
|
'CelerityPostprocessor' => 'Phobject',
|
||||||
'CelerityPostprocessorTestCase' => 'PhabricatorTestCase',
|
'CelerityPostprocessorTestCase' => 'PhabricatorTestCase',
|
||||||
|
'CelerityRedGreenPostprocessor' => 'CelerityPostprocessor',
|
||||||
'CelerityResourceController' => 'PhabricatorController',
|
'CelerityResourceController' => 'PhabricatorController',
|
||||||
'CelerityResourceGraph' => 'AbstractDirectedGraph',
|
'CelerityResourceGraph' => 'AbstractDirectedGraph',
|
||||||
'CelerityResourceMap' => 'Phobject',
|
'CelerityResourceMap' => 'Phobject',
|
||||||
|
@ -6949,7 +6970,16 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorConduitResultInterface',
|
'PhabricatorConduitResultInterface',
|
||||||
'PhabricatorNgramsInterface',
|
'PhabricatorNgramsInterface',
|
||||||
),
|
),
|
||||||
|
'PhabricatorBadgesBadgeAwardTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeDescriptionTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeFlavorTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeIconTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
'PhabricatorBadgesBadgeNameNgrams' => 'PhabricatorSearchNgrams',
|
'PhabricatorBadgesBadgeNameNgrams' => 'PhabricatorSearchNgrams',
|
||||||
|
'PhabricatorBadgesBadgeNameTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeQualityTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeRevokeTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeStatusTransaction' => 'PhabricatorBadgesBadgeTransactionType',
|
||||||
|
'PhabricatorBadgesBadgeTransactionType' => 'PhabricatorModularTransactionType',
|
||||||
'PhabricatorBadgesCommentController' => 'PhabricatorBadgesController',
|
'PhabricatorBadgesCommentController' => 'PhabricatorBadgesController',
|
||||||
'PhabricatorBadgesController' => 'PhabricatorController',
|
'PhabricatorBadgesController' => 'PhabricatorController',
|
||||||
'PhabricatorBadgesCreateCapability' => 'PhabricatorPolicyCapability',
|
'PhabricatorBadgesCreateCapability' => 'PhabricatorPolicyCapability',
|
||||||
|
@ -6975,7 +7005,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorBadgesSchemaSpec' => 'PhabricatorConfigSchemaSpec',
|
'PhabricatorBadgesSchemaSpec' => 'PhabricatorConfigSchemaSpec',
|
||||||
'PhabricatorBadgesSearchConduitAPIMethod' => 'PhabricatorSearchEngineAPIMethod',
|
'PhabricatorBadgesSearchConduitAPIMethod' => 'PhabricatorSearchEngineAPIMethod',
|
||||||
'PhabricatorBadgesSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
'PhabricatorBadgesSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'PhabricatorBadgesTransaction' => 'PhabricatorApplicationTransaction',
|
'PhabricatorBadgesTransaction' => 'PhabricatorModularTransaction',
|
||||||
'PhabricatorBadgesTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
'PhabricatorBadgesTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
||||||
'PhabricatorBadgesTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
'PhabricatorBadgesTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
||||||
'PhabricatorBadgesViewController' => 'PhabricatorBadgesProfileController',
|
'PhabricatorBadgesViewController' => 'PhabricatorBadgesProfileController',
|
||||||
|
@ -8445,6 +8475,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleAnyOwnerDatasource' => 'PhabricatorTypeaheadDatasource',
|
'PhabricatorPeopleAnyOwnerDatasource' => 'PhabricatorTypeaheadDatasource',
|
||||||
'PhabricatorPeopleApplication' => 'PhabricatorApplication',
|
'PhabricatorPeopleApplication' => 'PhabricatorApplication',
|
||||||
'PhabricatorPeopleApproveController' => 'PhabricatorPeopleController',
|
'PhabricatorPeopleApproveController' => 'PhabricatorPeopleController',
|
||||||
|
'PhabricatorPeopleBadgesProfileMenuItem' => 'PhabricatorProfileMenuItem',
|
||||||
'PhabricatorPeopleController' => 'PhabricatorController',
|
'PhabricatorPeopleController' => 'PhabricatorController',
|
||||||
'PhabricatorPeopleCreateController' => 'PhabricatorPeopleController',
|
'PhabricatorPeopleCreateController' => 'PhabricatorPeopleController',
|
||||||
'PhabricatorPeopleCreateGuidanceContext' => 'PhabricatorGuidanceContext',
|
'PhabricatorPeopleCreateGuidanceContext' => 'PhabricatorGuidanceContext',
|
||||||
|
@ -8468,6 +8499,7 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorPeopleNoOwnerDatasource' => 'PhabricatorTypeaheadDatasource',
|
'PhabricatorPeopleNoOwnerDatasource' => 'PhabricatorTypeaheadDatasource',
|
||||||
'PhabricatorPeopleOwnerDatasource' => 'PhabricatorTypeaheadCompositeDatasource',
|
'PhabricatorPeopleOwnerDatasource' => 'PhabricatorTypeaheadCompositeDatasource',
|
||||||
'PhabricatorPeoplePictureProfileMenuItem' => 'PhabricatorProfileMenuItem',
|
'PhabricatorPeoplePictureProfileMenuItem' => 'PhabricatorProfileMenuItem',
|
||||||
|
'PhabricatorPeopleProfileBadgesController' => 'PhabricatorPeopleProfileController',
|
||||||
'PhabricatorPeopleProfileController' => 'PhabricatorPeopleController',
|
'PhabricatorPeopleProfileController' => 'PhabricatorPeopleController',
|
||||||
'PhabricatorPeopleProfileEditController' => 'PhabricatorPeopleProfileController',
|
'PhabricatorPeopleProfileEditController' => 'PhabricatorPeopleProfileController',
|
||||||
'PhabricatorPeopleProfileManageController' => 'PhabricatorPeopleProfileController',
|
'PhabricatorPeopleProfileManageController' => 'PhabricatorPeopleProfileController',
|
||||||
|
@ -8522,24 +8554,29 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorNgramsInterface',
|
'PhabricatorNgramsInterface',
|
||||||
),
|
),
|
||||||
'PhabricatorPhurlURLAccessController' => 'PhabricatorPhurlController',
|
'PhabricatorPhurlURLAccessController' => 'PhabricatorPhurlController',
|
||||||
|
'PhabricatorPhurlURLAliasTransaction' => 'PhabricatorPhurlURLTransactionType',
|
||||||
'PhabricatorPhurlURLCommentController' => 'PhabricatorPhurlController',
|
'PhabricatorPhurlURLCommentController' => 'PhabricatorPhurlController',
|
||||||
'PhabricatorPhurlURLCreateCapability' => 'PhabricatorPolicyCapability',
|
'PhabricatorPhurlURLCreateCapability' => 'PhabricatorPolicyCapability',
|
||||||
'PhabricatorPhurlURLDatasource' => 'PhabricatorTypeaheadDatasource',
|
'PhabricatorPhurlURLDatasource' => 'PhabricatorTypeaheadDatasource',
|
||||||
|
'PhabricatorPhurlURLDescriptionTransaction' => 'PhabricatorPhurlURLTransactionType',
|
||||||
'PhabricatorPhurlURLEditConduitAPIMethod' => 'PhabricatorEditEngineAPIMethod',
|
'PhabricatorPhurlURLEditConduitAPIMethod' => 'PhabricatorEditEngineAPIMethod',
|
||||||
'PhabricatorPhurlURLEditController' => 'PhabricatorPhurlController',
|
'PhabricatorPhurlURLEditController' => 'PhabricatorPhurlController',
|
||||||
'PhabricatorPhurlURLEditEngine' => 'PhabricatorEditEngine',
|
'PhabricatorPhurlURLEditEngine' => 'PhabricatorEditEngine',
|
||||||
'PhabricatorPhurlURLEditor' => 'PhabricatorApplicationTransactionEditor',
|
'PhabricatorPhurlURLEditor' => 'PhabricatorApplicationTransactionEditor',
|
||||||
'PhabricatorPhurlURLListController' => 'PhabricatorPhurlController',
|
'PhabricatorPhurlURLListController' => 'PhabricatorPhurlController',
|
||||||
|
'PhabricatorPhurlURLLongURLTransaction' => 'PhabricatorPhurlURLTransactionType',
|
||||||
'PhabricatorPhurlURLMailReceiver' => 'PhabricatorObjectMailReceiver',
|
'PhabricatorPhurlURLMailReceiver' => 'PhabricatorObjectMailReceiver',
|
||||||
'PhabricatorPhurlURLNameNgrams' => 'PhabricatorSearchNgrams',
|
'PhabricatorPhurlURLNameNgrams' => 'PhabricatorSearchNgrams',
|
||||||
|
'PhabricatorPhurlURLNameTransaction' => 'PhabricatorPhurlURLTransactionType',
|
||||||
'PhabricatorPhurlURLPHIDType' => 'PhabricatorPHIDType',
|
'PhabricatorPhurlURLPHIDType' => 'PhabricatorPHIDType',
|
||||||
'PhabricatorPhurlURLQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
'PhabricatorPhurlURLQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
||||||
'PhabricatorPhurlURLReplyHandler' => 'PhabricatorApplicationTransactionReplyHandler',
|
'PhabricatorPhurlURLReplyHandler' => 'PhabricatorApplicationTransactionReplyHandler',
|
||||||
'PhabricatorPhurlURLSearchConduitAPIMethod' => 'PhabricatorSearchEngineAPIMethod',
|
'PhabricatorPhurlURLSearchConduitAPIMethod' => 'PhabricatorSearchEngineAPIMethod',
|
||||||
'PhabricatorPhurlURLSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
'PhabricatorPhurlURLSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'PhabricatorPhurlURLTransaction' => 'PhabricatorApplicationTransaction',
|
'PhabricatorPhurlURLTransaction' => 'PhabricatorModularTransaction',
|
||||||
'PhabricatorPhurlURLTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
'PhabricatorPhurlURLTransactionComment' => 'PhabricatorApplicationTransactionComment',
|
||||||
'PhabricatorPhurlURLTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
'PhabricatorPhurlURLTransactionQuery' => 'PhabricatorApplicationTransactionQuery',
|
||||||
|
'PhabricatorPhurlURLTransactionType' => 'PhabricatorModularTransactionType',
|
||||||
'PhabricatorPhurlURLViewController' => 'PhabricatorPhurlController',
|
'PhabricatorPhurlURLViewController' => 'PhabricatorPhurlController',
|
||||||
'PhabricatorPinnedApplicationsSetting' => 'PhabricatorInternalSetting',
|
'PhabricatorPinnedApplicationsSetting' => 'PhabricatorInternalSetting',
|
||||||
'PhabricatorPirateEnglishTranslation' => 'PhutilTranslation',
|
'PhabricatorPirateEnglishTranslation' => 'PhutilTranslation',
|
||||||
|
@ -9436,12 +9473,18 @@ phutil_register_library_map(array(
|
||||||
'PhabricatorXHProfApplication' => 'PhabricatorApplication',
|
'PhabricatorXHProfApplication' => 'PhabricatorApplication',
|
||||||
'PhabricatorXHProfController' => 'PhabricatorController',
|
'PhabricatorXHProfController' => 'PhabricatorController',
|
||||||
'PhabricatorXHProfDAO' => 'PhabricatorLiskDAO',
|
'PhabricatorXHProfDAO' => 'PhabricatorLiskDAO',
|
||||||
|
'PhabricatorXHProfDropController' => 'PhabricatorXHProfController',
|
||||||
'PhabricatorXHProfProfileController' => 'PhabricatorXHProfController',
|
'PhabricatorXHProfProfileController' => 'PhabricatorXHProfController',
|
||||||
'PhabricatorXHProfProfileSymbolView' => 'PhabricatorXHProfProfileView',
|
'PhabricatorXHProfProfileSymbolView' => 'PhabricatorXHProfProfileView',
|
||||||
'PhabricatorXHProfProfileTopLevelView' => 'PhabricatorXHProfProfileView',
|
'PhabricatorXHProfProfileTopLevelView' => 'PhabricatorXHProfProfileView',
|
||||||
'PhabricatorXHProfProfileView' => 'AphrontView',
|
'PhabricatorXHProfProfileView' => 'AphrontView',
|
||||||
'PhabricatorXHProfSample' => 'PhabricatorXHProfDAO',
|
'PhabricatorXHProfSample' => array(
|
||||||
|
'PhabricatorXHProfDAO',
|
||||||
|
'PhabricatorPolicyInterface',
|
||||||
|
),
|
||||||
'PhabricatorXHProfSampleListController' => 'PhabricatorXHProfController',
|
'PhabricatorXHProfSampleListController' => 'PhabricatorXHProfController',
|
||||||
|
'PhabricatorXHProfSampleQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
|
||||||
|
'PhabricatorXHProfSampleSearchEngine' => 'PhabricatorApplicationSearchEngine',
|
||||||
'PhabricatorYoutubeRemarkupRule' => 'PhutilRemarkupRule',
|
'PhabricatorYoutubeRemarkupRule' => 'PhutilRemarkupRule',
|
||||||
'Phame404Response' => 'AphrontHTMLResponse',
|
'Phame404Response' => 'AphrontHTMLResponse',
|
||||||
'PhameBlog' => array(
|
'PhameBlog' => array(
|
||||||
|
|
|
@ -4,7 +4,7 @@ final class PhabricatorCommitSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Commits');
|
return pht('Diffusion Commits');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
|
|
|
@ -4,13 +4,17 @@ final class PhabricatorAuthInviteSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Email Invites');
|
return pht('Auth Email Invites');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
return 'PhabricatorAuthApplication';
|
return 'PhabricatorAuthApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
$saved = new PhabricatorSavedQuery();
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,8 @@ final class PhabricatorBadgesArchiveController
|
||||||
$xactions = array();
|
$xactions = array();
|
||||||
|
|
||||||
$xactions[] = id(new PhabricatorBadgesTransaction())
|
$xactions[] = id(new PhabricatorBadgesTransaction())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_STATUS)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeStatusTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($new_status);
|
->setNewValue($new_status);
|
||||||
|
|
||||||
id(new PhabricatorBadgesEditor())
|
id(new PhabricatorBadgesEditor())
|
||||||
|
|
|
@ -15,7 +15,7 @@ final class PhabricatorBadgesAwardController
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
|
||||||
$view_uri = '/p/'.$user->getUsername();
|
$view_uri = '/people/badges/'.$user->getID().'/';
|
||||||
|
|
||||||
if ($request->isFormPost()) {
|
if ($request->isFormPost()) {
|
||||||
$badge_phids = $request->getArr('badgePHIDs');
|
$badge_phids = $request->getArr('badgePHIDs');
|
||||||
|
@ -37,7 +37,8 @@ final class PhabricatorBadgesAwardController
|
||||||
foreach ($badges as $badge) {
|
foreach ($badges as $badge) {
|
||||||
$xactions = array();
|
$xactions = array();
|
||||||
$xactions[] = id(new PhabricatorBadgesTransaction())
|
$xactions[] = id(new PhabricatorBadgesTransaction())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_AWARD)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeAwardTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($award_phids);
|
->setNewValue($award_phids);
|
||||||
|
|
||||||
$editor = id(new PhabricatorBadgesEditor())
|
$editor = id(new PhabricatorBadgesEditor())
|
||||||
|
@ -66,7 +67,7 @@ final class PhabricatorBadgesAwardController
|
||||||
))));
|
))));
|
||||||
|
|
||||||
$dialog = $this->newDialog()
|
$dialog = $this->newDialog()
|
||||||
->setTitle(pht('Grant Badge'))
|
->setTitle(pht('Award Badge'))
|
||||||
->appendForm($form)
|
->appendForm($form)
|
||||||
->addCancelButton($view_uri)
|
->addCancelButton($view_uri)
|
||||||
->addSubmitButton(pht('Award'));
|
->addSubmitButton(pht('Award'));
|
||||||
|
|
|
@ -37,7 +37,8 @@ final class PhabricatorBadgesEditRecipientsController
|
||||||
}
|
}
|
||||||
|
|
||||||
$xactions[] = id(new PhabricatorBadgesTransaction())
|
$xactions[] = id(new PhabricatorBadgesTransaction())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_AWARD)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeAwardTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue($award_phids);
|
->setNewValue($award_phids);
|
||||||
|
|
||||||
$editor = id(new PhabricatorBadgesEditor())
|
$editor = id(new PhabricatorBadgesEditor())
|
||||||
|
|
|
@ -29,12 +29,13 @@ final class PhabricatorBadgesRemoveRecipientsController
|
||||||
return new Aphront404Response();
|
return new Aphront404Response();
|
||||||
}
|
}
|
||||||
|
|
||||||
$view_uri = $this->getApplicationURI('view/'.$badge->getID().'/');
|
$view_uri = $this->getApplicationURI('recipients/'.$badge->getID().'/');
|
||||||
|
|
||||||
if ($request->isFormPost()) {
|
if ($request->isFormPost()) {
|
||||||
$xactions = array();
|
$xactions = array();
|
||||||
$xactions[] = id(new PhabricatorBadgesTransaction())
|
$xactions[] = id(new PhabricatorBadgesTransaction())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_REVOKE)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeRevokeTransaction::TRANSACTIONTYPE)
|
||||||
->setNewValue(array($remove_phid));
|
->setNewValue(array($remove_phid));
|
||||||
|
|
||||||
$editor = id(new PhabricatorBadgesEditor())
|
$editor = id(new PhabricatorBadgesEditor())
|
||||||
|
|
|
@ -90,7 +90,6 @@ final class PhabricatorBadgesViewController
|
||||||
$id = $badge->getID();
|
$id = $badge->getID();
|
||||||
$edit_uri = $this->getApplicationURI("/edit/{$id}/");
|
$edit_uri = $this->getApplicationURI("/edit/{$id}/");
|
||||||
$archive_uri = $this->getApplicationURI("/archive/{$id}/");
|
$archive_uri = $this->getApplicationURI("/archive/{$id}/");
|
||||||
$award_uri = $this->getApplicationURI("/recipients/{$id}/add/");
|
|
||||||
|
|
||||||
$curtain = $this->newCurtainView($badge);
|
$curtain = $this->newCurtainView($badge);
|
||||||
|
|
||||||
|
@ -119,14 +118,6 @@ final class PhabricatorBadgesViewController
|
||||||
->setHref($archive_uri));
|
->setHref($archive_uri));
|
||||||
}
|
}
|
||||||
|
|
||||||
$curtain->addAction(
|
|
||||||
id(new PhabricatorActionView())
|
|
||||||
->setName('Add Recipients')
|
|
||||||
->setIcon('fa-users')
|
|
||||||
->setDisabled(!$can_edit)
|
|
||||||
->setWorkflow(true)
|
|
||||||
->setHref($award_uri));
|
|
||||||
|
|
||||||
return $curtain;
|
return $curtain;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,10 @@ final class PhabricatorBadgesEditEngine
|
||||||
return pht('Configure creation and editing forms in Badges.');
|
return pht('Configure creation and editing forms in Badges.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function isEngineConfigurable() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function newEditableObject() {
|
protected function newEditableObject() {
|
||||||
return PhabricatorBadgesBadge::initializeNewBadge($this->getViewer());
|
return PhabricatorBadgesBadge::initializeNewBadge($this->getViewer());
|
||||||
}
|
}
|
||||||
|
@ -82,20 +86,24 @@ final class PhabricatorBadgesEditEngine
|
||||||
->setLabel(pht('Name'))
|
->setLabel(pht('Name'))
|
||||||
->setDescription(pht('Badge name.'))
|
->setDescription(pht('Badge name.'))
|
||||||
->setConduitTypeDescription(pht('New badge name.'))
|
->setConduitTypeDescription(pht('New badge name.'))
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_NAME)
|
->setTransactionType(
|
||||||
->setValue($object->getName()),
|
PhabricatorBadgesBadgeNameTransaction::TRANSACTIONTYPE)
|
||||||
|
->setValue($object->getName())
|
||||||
|
->setIsRequired(true),
|
||||||
id(new PhabricatorTextEditField())
|
id(new PhabricatorTextEditField())
|
||||||
->setKey('flavor')
|
->setKey('flavor')
|
||||||
->setLabel(pht('Flavor text'))
|
->setLabel(pht('Flavor Text'))
|
||||||
->setDescription(pht('Short description of the badge.'))
|
->setDescription(pht('Short description of the badge.'))
|
||||||
->setConduitTypeDescription(pht('New badge flavor.'))
|
->setConduitTypeDescription(pht('New badge flavor.'))
|
||||||
->setValue($object->getFlavor())
|
->setValue($object->getFlavor())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_FLAVOR),
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeFlavorTransaction::TRANSACTIONTYPE),
|
||||||
id(new PhabricatorIconSetEditField())
|
id(new PhabricatorIconSetEditField())
|
||||||
->setKey('icon')
|
->setKey('icon')
|
||||||
->setLabel(pht('Icon'))
|
->setLabel(pht('Icon'))
|
||||||
->setIconSet(new PhabricatorBadgesIconSet())
|
->setIconSet(new PhabricatorBadgesIconSet())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_ICON)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeIconTransaction::TRANSACTIONTYPE)
|
||||||
->setConduitDescription(pht('Change the badge icon.'))
|
->setConduitDescription(pht('Change the badge icon.'))
|
||||||
->setConduitTypeDescription(pht('New badge icon.'))
|
->setConduitTypeDescription(pht('New badge icon.'))
|
||||||
->setValue($object->getIcon()),
|
->setValue($object->getIcon()),
|
||||||
|
@ -105,14 +113,16 @@ final class PhabricatorBadgesEditEngine
|
||||||
->setDescription(pht('Color and rarity of the badge.'))
|
->setDescription(pht('Color and rarity of the badge.'))
|
||||||
->setConduitTypeDescription(pht('New badge quality.'))
|
->setConduitTypeDescription(pht('New badge quality.'))
|
||||||
->setValue($object->getQuality())
|
->setValue($object->getQuality())
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_QUALITY)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeQualityTransaction::TRANSACTIONTYPE)
|
||||||
->setOptions(PhabricatorBadgesQuality::getDropdownQualityMap()),
|
->setOptions(PhabricatorBadgesQuality::getDropdownQualityMap()),
|
||||||
id(new PhabricatorRemarkupEditField())
|
id(new PhabricatorRemarkupEditField())
|
||||||
->setKey('description')
|
->setKey('description')
|
||||||
->setLabel(pht('Description'))
|
->setLabel(pht('Description'))
|
||||||
->setDescription(pht('Badge long description.'))
|
->setDescription(pht('Badge long description.'))
|
||||||
->setConduitTypeDescription(pht('New badge description.'))
|
->setConduitTypeDescription(pht('New badge description.'))
|
||||||
->setTransactionType(PhabricatorBadgesTransaction::TYPE_DESCRIPTION)
|
->setTransactionType(
|
||||||
|
PhabricatorBadgesBadgeDescriptionTransaction::TRANSACTIONTYPE)
|
||||||
->setValue($object->getDescription()),
|
->setValue($object->getDescription()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,22 +11,20 @@ final class PhabricatorBadgesEditor
|
||||||
return pht('Badges');
|
return pht('Badges');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getCreateObjectTitle($author, $object) {
|
||||||
|
return pht('%s created this badge.', $author);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCreateObjectTitleForFeed($author, $object) {
|
||||||
|
return pht('%s created %s.', $author, $object);
|
||||||
|
}
|
||||||
|
|
||||||
protected function supportsSearch() {
|
protected function supportsSearch() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getTransactionTypes() {
|
public function getTransactionTypes() {
|
||||||
$types = parent::getTransactionTypes();
|
$types = parent::getTransactionTypes();
|
||||||
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_NAME;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_FLAVOR;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_DESCRIPTION;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_ICON;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_STATUS;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_QUALITY;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_AWARD;
|
|
||||||
$types[] = PhabricatorBadgesTransaction::TYPE_REVOKE;
|
|
||||||
|
|
||||||
$types[] = PhabricatorTransactions::TYPE_COMMENT;
|
$types[] = PhabricatorTransactions::TYPE_COMMENT;
|
||||||
$types[] = PhabricatorTransactions::TYPE_EDGE;
|
$types[] = PhabricatorTransactions::TYPE_EDGE;
|
||||||
$types[] = PhabricatorTransactions::TYPE_EDIT_POLICY;
|
$types[] = PhabricatorTransactions::TYPE_EDIT_POLICY;
|
||||||
|
@ -34,159 +32,6 @@ final class PhabricatorBadgesEditor
|
||||||
return $types;
|
return $types;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getCustomTransactionOldValue(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_NAME:
|
|
||||||
return $object->getName();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_FLAVOR:
|
|
||||||
return $object->getFlavor();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_DESCRIPTION:
|
|
||||||
return $object->getDescription();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_ICON:
|
|
||||||
return $object->getIcon();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_QUALITY:
|
|
||||||
return (int)$object->getQuality();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_STATUS:
|
|
||||||
return $object->getStatus();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_AWARD:
|
|
||||||
$award_phids = mpull($object->getAwards(), 'getRecipientPHID');
|
|
||||||
return $award_phids;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_REVOKE:
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getCustomTransactionOldValue($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getCustomTransactionNewValue(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_NAME:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_FLAVOR:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_DESCRIPTION:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_ICON:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_STATUS:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_AWARD:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_REVOKE:
|
|
||||||
return $xaction->getNewValue();
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_QUALITY:
|
|
||||||
return (int)$xaction->getNewValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getCustomTransactionNewValue($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomInternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
$type = $xaction->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_NAME:
|
|
||||||
$object->setName($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_FLAVOR:
|
|
||||||
$object->setFlavor($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_DESCRIPTION:
|
|
||||||
$object->setDescription($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_ICON:
|
|
||||||
$object->setIcon($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_QUALITY:
|
|
||||||
$object->setQuality($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_STATUS:
|
|
||||||
$object->setStatus($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_AWARD:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_REVOKE:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::applyCustomInternalTransaction($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomExternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
$type = $xaction->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_NAME:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_FLAVOR:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_DESCRIPTION:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_ICON:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_STATUS:
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_QUALITY:
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_REVOKE:
|
|
||||||
$revoked_recipient_phids = $xaction->getNewValue();
|
|
||||||
$awards = $object->getAwards();
|
|
||||||
$awards = mpull($awards, null, 'getRecipientPHID');
|
|
||||||
|
|
||||||
foreach ($revoked_recipient_phids as $phid) {
|
|
||||||
$awards[$phid]->delete();
|
|
||||||
}
|
|
||||||
$object->attachAwards($awards);
|
|
||||||
return;
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_AWARD:
|
|
||||||
$recipient_phids = $xaction->getNewValue();
|
|
||||||
$awards = $object->getAwards();
|
|
||||||
$awards = mpull($awards, null, 'getRecipientPHID');
|
|
||||||
|
|
||||||
foreach ($recipient_phids as $phid) {
|
|
||||||
$award = idx($awards, $phid);
|
|
||||||
if (!$award) {
|
|
||||||
$award = PhabricatorBadgesAward::initializeNewBadgesAward(
|
|
||||||
$this->getActor(),
|
|
||||||
$object,
|
|
||||||
$phid);
|
|
||||||
$award->save();
|
|
||||||
$awards[] = $award;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$object->attachAwards($awards);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::applyCustomExternalTransaction($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function validateTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
$type,
|
|
||||||
array $xactions) {
|
|
||||||
|
|
||||||
$errors = parent::validateTransaction($object, $type, $xactions);
|
|
||||||
|
|
||||||
switch ($type) {
|
|
||||||
case PhabricatorBadgesTransaction::TYPE_NAME:
|
|
||||||
$missing = $this->validateIsEmptyTextField(
|
|
||||||
$object->getName(),
|
|
||||||
$xactions);
|
|
||||||
|
|
||||||
if ($missing) {
|
|
||||||
$error = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Required'),
|
|
||||||
pht('Badge name is required.'),
|
|
||||||
nonempty(last($xactions), null));
|
|
||||||
|
|
||||||
$error->setIsMissingFieldError(true);
|
|
||||||
$errors[] = $error;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $errors;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function shouldSendMail(
|
protected function shouldSendMail(
|
||||||
PhabricatorLiskDAO $object,
|
PhabricatorLiskDAO $object,
|
||||||
array $xactions) {
|
array $xactions) {
|
||||||
|
@ -210,6 +55,30 @@ final class PhabricatorBadgesEditor
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function expandTransactions(
|
||||||
|
PhabricatorLiskDAO $object,
|
||||||
|
array $xactions) {
|
||||||
|
|
||||||
|
$actor = $this->getActor();
|
||||||
|
$actor_phid = $actor->getPHID();
|
||||||
|
|
||||||
|
$results = parent::expandTransactions($object, $xactions);
|
||||||
|
|
||||||
|
// Automatically subscribe the author when they create a badge.
|
||||||
|
if ($this->getIsNewObject()) {
|
||||||
|
if ($actor_phid) {
|
||||||
|
$results[] = id(new PhabricatorBadgesTransaction())
|
||||||
|
->setTransactionType(PhabricatorTransactions::TYPE_SUBSCRIBERS)
|
||||||
|
->setNewValue(
|
||||||
|
array(
|
||||||
|
'+' => array($actor_phid => $actor_phid),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $results;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildReplyHandler(PhabricatorLiskDAO $object) {
|
protected function buildReplyHandler(PhabricatorLiskDAO $object) {
|
||||||
return id(new PhabricatorBadgesReplyHandler())
|
return id(new PhabricatorBadgesReplyHandler())
|
||||||
->setMailReceiver($object);
|
->setMailReceiver($object);
|
||||||
|
|
|
@ -4,7 +4,7 @@ final class PhabricatorBadgesSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Badge');
|
return pht('Badges');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
|
@ -147,7 +147,7 @@ final class PhabricatorBadgesSearchEngine
|
||||||
->setTitle(pht('Welcome to %s', $app_name))
|
->setTitle(pht('Welcome to %s', $app_name))
|
||||||
->setDescription(
|
->setDescription(
|
||||||
pht('Badges let you award and distinguish special users '.
|
pht('Badges let you award and distinguish special users '.
|
||||||
'throughout your instance.'))
|
'throughout your install.'))
|
||||||
->addAction($create_button);
|
->addAction($create_button);
|
||||||
|
|
||||||
return $view;
|
return $view;
|
||||||
|
|
|
@ -156,7 +156,7 @@ final class PhabricatorBadgesBadge extends PhabricatorBadgesDAO
|
||||||
|
|
||||||
|
|
||||||
public function isAutomaticallySubscribed($phid) {
|
public function isAutomaticallySubscribed($phid) {
|
||||||
return ($this->creatorPHID == $phid);
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,16 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class PhabricatorBadgesTransaction
|
final class PhabricatorBadgesTransaction
|
||||||
extends PhabricatorApplicationTransaction {
|
extends PhabricatorModularTransaction {
|
||||||
|
|
||||||
const TYPE_NAME = 'badges:name';
|
|
||||||
const TYPE_DESCRIPTION = 'badges:description';
|
|
||||||
const TYPE_QUALITY = 'badges:quality';
|
|
||||||
const TYPE_ICON = 'badges:icon';
|
|
||||||
const TYPE_STATUS = 'badges:status';
|
|
||||||
const TYPE_FLAVOR = 'badges:flavor';
|
|
||||||
const TYPE_AWARD = 'badges:award';
|
|
||||||
const TYPE_REVOKE = 'badges:revoke';
|
|
||||||
|
|
||||||
const MAILTAG_DETAILS = 'badges:details';
|
const MAILTAG_DETAILS = 'badges:details';
|
||||||
const MAILTAG_COMMENT = 'badges:comment';
|
const MAILTAG_COMMENT = 'badges:comment';
|
||||||
|
@ -28,209 +19,8 @@ final class PhabricatorBadgesTransaction
|
||||||
return new PhabricatorBadgesTransactionComment();
|
return new PhabricatorBadgesTransactionComment();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getBaseTransactionClass() {
|
||||||
public function getTitle() {
|
return 'PhabricatorBadgesBadgeTransactionType';
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
$object_phid = $this->getObjectPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case PhabricatorTransactions::TYPE_CREATE:
|
|
||||||
return pht(
|
|
||||||
'%s created this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s renamed this badge from "%s" to "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_FLAVOR:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the flavor text for this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s updated the flavor text for this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the description for this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s updated the description for this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_STATUS:
|
|
||||||
switch ($new) {
|
|
||||||
case PhabricatorBadgesBadge::STATUS_ACTIVE:
|
|
||||||
return pht(
|
|
||||||
'%s activated this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
case PhabricatorBadgesBadge::STATUS_ARCHIVED:
|
|
||||||
return pht(
|
|
||||||
'%s archived this badge.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_ICON:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the icon for this badge as "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$new);
|
|
||||||
} else {
|
|
||||||
$set = new PhabricatorBadgesIconSet();
|
|
||||||
|
|
||||||
$icon_old = $set->getIconLabel($old);
|
|
||||||
$icon_new = $set->getIconLabel($new);
|
|
||||||
|
|
||||||
return pht(
|
|
||||||
'%s updated the icon for this badge from "%s" to "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$icon_old,
|
|
||||||
$icon_new);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_QUALITY:
|
|
||||||
$qual_new = PhabricatorBadgesQuality::getQualityName($new);
|
|
||||||
$qual_old = PhabricatorBadgesQuality::getQualityName($old);
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the quality for this badge as "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$qual_new);
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s updated the quality for this badge from "%s" to "%s".',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$qual_old,
|
|
||||||
$qual_new);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_AWARD:
|
|
||||||
if (!is_array($new)) {
|
|
||||||
$new = array();
|
|
||||||
}
|
|
||||||
$handles = $this->renderHandleList($new);
|
|
||||||
return pht(
|
|
||||||
'%s awarded this badge to %s recipient(s): %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
new PhutilNumber(count($new)),
|
|
||||||
$handles);
|
|
||||||
case self::TYPE_REVOKE:
|
|
||||||
if (!is_array($new)) {
|
|
||||||
$new = array();
|
|
||||||
}
|
|
||||||
$handles = $this->renderHandleList($new);
|
|
||||||
return pht(
|
|
||||||
'%s revoked this badge from %s recipient(s): %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
new PhutilNumber(count($new)),
|
|
||||||
$handles);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getTitle();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitleForFeed() {
|
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
$object_phid = $this->getObjectPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s renamed %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_FLAVOR:
|
|
||||||
return pht(
|
|
||||||
'%s updated the flavor text for %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
case self::TYPE_ICON:
|
|
||||||
return pht(
|
|
||||||
'%s updated the icon for %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
case self::TYPE_QUALITY:
|
|
||||||
return pht(
|
|
||||||
'%s updated the quality level for %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return pht(
|
|
||||||
'%s updated the description for %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
case self::TYPE_STATUS:
|
|
||||||
switch ($new) {
|
|
||||||
case PhabricatorBadgesBadge::STATUS_ACTIVE:
|
|
||||||
return pht(
|
|
||||||
'%s activated %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
case PhabricatorBadgesBadge::STATUS_ARCHIVED:
|
|
||||||
return pht(
|
|
||||||
'%s archived %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case self::TYPE_AWARD:
|
|
||||||
if (!is_array($new)) {
|
|
||||||
$new = array();
|
|
||||||
}
|
|
||||||
$handles = $this->renderHandleList($new);
|
|
||||||
return pht(
|
|
||||||
'%s awarded %s to %s recipient(s): %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
new PhutilNumber(count($new)),
|
|
||||||
$handles);
|
|
||||||
case self::TYPE_REVOKE:
|
|
||||||
if (!is_array($new)) {
|
|
||||||
$new = array();
|
|
||||||
}
|
|
||||||
$handles = $this->renderHandleList($new);
|
|
||||||
return pht(
|
|
||||||
'%s revoked %s from %s recipient(s): %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
new PhutilNumber(count($new)),
|
|
||||||
$handles);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getTitleForFeed();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getMailTags() {
|
public function getMailTags() {
|
||||||
|
@ -240,14 +30,16 @@ final class PhabricatorBadgesTransaction
|
||||||
case PhabricatorTransactions::TYPE_COMMENT:
|
case PhabricatorTransactions::TYPE_COMMENT:
|
||||||
$tags[] = self::MAILTAG_COMMENT;
|
$tags[] = self::MAILTAG_COMMENT;
|
||||||
break;
|
break;
|
||||||
case self::TYPE_NAME:
|
case PhabricatorBadgesBadgeNameTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_DESCRIPTION:
|
case PhabricatorBadgesBadgeDescriptionTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_FLAVOR:
|
case PhabricatorBadgesBadgeFlavorTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_ICON:
|
case PhabricatorBadgesBadgeIconTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_STATUS:
|
case PhabricatorBadgesBadgeStatusTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_QUALITY:
|
case PhabricatorBadgesBadgeQualityTransaction::TRANSACTIONTYPE:
|
||||||
$tags[] = self::MAILTAG_DETAILS;
|
$tags[] = self::MAILTAG_DETAILS;
|
||||||
break;
|
break;
|
||||||
|
case PhabricatorBadgesBadgeAwardTransaction::TRANSACTIONTYPE:
|
||||||
|
case PhabricatorBadgesBadgeRevokeTransaction::TRANSACTIONTYPE:
|
||||||
default:
|
default:
|
||||||
$tags[] = self::MAILTAG_OTHER;
|
$tags[] = self::MAILTAG_OTHER;
|
||||||
break;
|
break;
|
||||||
|
@ -255,49 +47,4 @@ final class PhabricatorBadgesTransaction
|
||||||
return $tags;
|
return $tags;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function shouldHide() {
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return ($old === null);
|
|
||||||
}
|
|
||||||
return parent::shouldHide();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function hasChangeDetails() {
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return ($this->getOldValue() !== null);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::hasChangeDetails();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function renderChangeDetails(PhabricatorUser $viewer) {
|
|
||||||
return $this->renderTextCorpusChangeDetails(
|
|
||||||
$viewer,
|
|
||||||
$this->getOldValue(),
|
|
||||||
$this->getNewValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getRequiredHandlePHIDs() {
|
|
||||||
$phids = parent::getRequiredHandlePHIDs();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_AWARD:
|
|
||||||
case self::TYPE_REVOKE:
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
if (!is_array($new)) {
|
|
||||||
$new = array();
|
|
||||||
}
|
|
||||||
foreach ($new as $phid) {
|
|
||||||
$phids[] = $phid;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $phids;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,90 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeAwardTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.award';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return mpull($object->getAwards(), 'getRecipientPHID');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyExternalEffects($object, $value) {
|
||||||
|
$awards = $object->getAwards();
|
||||||
|
$awards = mpull($awards, null, 'getRecipientPHID');
|
||||||
|
|
||||||
|
foreach ($value as $phid) {
|
||||||
|
$award = idx($awards, $phid);
|
||||||
|
if (!$award) {
|
||||||
|
$award = PhabricatorBadgesAward::initializeNewBadgesAward(
|
||||||
|
$this->getActor(),
|
||||||
|
$object,
|
||||||
|
$phid);
|
||||||
|
$award->save();
|
||||||
|
$awards[] = $award;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$object->attachAwards($awards);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
if (!is_array($new)) {
|
||||||
|
$new = array();
|
||||||
|
}
|
||||||
|
$handles = $this->renderHandleList($new);
|
||||||
|
return pht(
|
||||||
|
'%s awarded this badge to %s recipient(s): %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
new PhutilNumber(count($new)),
|
||||||
|
$handles);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
if (!is_array($new)) {
|
||||||
|
$new = array();
|
||||||
|
}
|
||||||
|
$handles = $this->renderHandleList($new);
|
||||||
|
return pht(
|
||||||
|
'%s awarded %s to %s recipient(s): %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
new PhutilNumber(count($new)),
|
||||||
|
$handles);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-user-plus';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
$user_phids = $xaction->getNewValue();
|
||||||
|
if (!$user_phids) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Recipient is required.'));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($user_phids as $user_phid) {
|
||||||
|
$user = id(new PhabricatorPeopleQuery())
|
||||||
|
->setViewer($this->getActor())
|
||||||
|
->withPHIDs(array($user_phid))
|
||||||
|
->executeOne();
|
||||||
|
if (!$user) {
|
||||||
|
$errors[] = $this->newInvalidError(
|
||||||
|
pht(
|
||||||
|
'Recipient PHID "%s" is not a valid user PHID.',
|
||||||
|
$user_phid));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,57 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeDescriptionTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.description';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setDescription($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the badge description.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the badge description for %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function hasChangeDetailView() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getMailDiffSectionHeader() {
|
||||||
|
return pht('CHANGES TO BADGE DESCRIPTION');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newChangeDetailView() {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
|
||||||
|
return id(new PhabricatorApplicationTransactionTextDiffDetailView())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->setOldText($this->getOldValue())
|
||||||
|
->setNewText($this->getNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newRemarkupChanges() {
|
||||||
|
$changes = array();
|
||||||
|
|
||||||
|
$changes[] = $this->newRemarkupChange()
|
||||||
|
->setOldValue($this->getOldValue())
|
||||||
|
->setNewValue($this->getNewValue());
|
||||||
|
|
||||||
|
return $changes;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeFlavorTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.flavor';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getFlavor();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setFlavor($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the flavor from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s updated %s flavor text from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
$max_length = $object->getColumnMaximumByteLength('flavor');
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
$new_value = $xaction->getNewValue();
|
||||||
|
$new_length = strlen($new_value);
|
||||||
|
if ($new_length > $max_length) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The flavor text can be no longer than %s characters.',
|
||||||
|
new PhutilNumber($max_length)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,56 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeIconTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.icon';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getIcon();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setIcon($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function shouldHide() {
|
||||||
|
if ($this->isCreateTransaction()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$old = $this->getIconLabel($this->getOldValue());
|
||||||
|
$new = $this->getIconLabel($this->getNewValue());
|
||||||
|
|
||||||
|
return pht(
|
||||||
|
'%s changed the badge icon from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderValue($old),
|
||||||
|
$this->renderValue($new));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$old = $this->getIconLabel($this->getOldValue());
|
||||||
|
$new = $this->getIconLabel($this->getNewValue());
|
||||||
|
|
||||||
|
return pht(
|
||||||
|
'%s changed the badge icon for %s from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderValue($old),
|
||||||
|
$this->renderValue($new));
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getIconLabel($icon) {
|
||||||
|
$set = new PhabricatorBadgesIconSet();
|
||||||
|
return $set->getIconLabel($icon);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return $this->getNewValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,55 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeNameTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.name';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setName($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s renamed this badge from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s renamed %s badge %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getName(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Badges must have a name.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$max_length = $object->getColumnMaximumByteLength('name');
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
$new_value = $xaction->getNewValue();
|
||||||
|
$new_length = strlen($new_value);
|
||||||
|
if ($new_length > $max_length) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The name can be no longer than %s characters.',
|
||||||
|
new PhutilNumber($max_length)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,70 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeQualityTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.quality';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getQuality();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setQuality($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function shouldHide() {
|
||||||
|
if ($this->isCreateTransaction()) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$old = $this->getQualityLabel($this->getOldValue());
|
||||||
|
$new = $this->getQualityLabel($this->getNewValue());
|
||||||
|
|
||||||
|
return pht(
|
||||||
|
'%s updated the quality from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$old,
|
||||||
|
$new);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$old = $this->getQualityLabel($this->getOldValue());
|
||||||
|
$new = $this->getQualityLabel($this->getNewValue());
|
||||||
|
|
||||||
|
return pht(
|
||||||
|
'%s updated %s quality from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$new,
|
||||||
|
$old);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getQuality(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Badge quality must be set.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$map = PhabricatorBadgesQuality::getQualityMap();
|
||||||
|
if (!$map[$object->getQuality()]) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Badge quality is not valid.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getQualityLabel($quality) {
|
||||||
|
$map = PhabricatorBadgesQuality::getQualityMap();
|
||||||
|
$name = $map[$quality]['name'];
|
||||||
|
return $this->renderValue($name);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,83 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeRevokeTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badge.revoke';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyExternalEffects($object, $value) {
|
||||||
|
$awards = $object->getAwards();
|
||||||
|
$awards = mpull($awards, null, 'getRecipientPHID');
|
||||||
|
|
||||||
|
foreach ($value as $phid) {
|
||||||
|
$awards[$phid]->delete();
|
||||||
|
}
|
||||||
|
$object->attachAwards($awards);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
if (!is_array($new)) {
|
||||||
|
$new = array();
|
||||||
|
}
|
||||||
|
$handles = $this->renderHandleList($new);
|
||||||
|
return pht(
|
||||||
|
'%s revoked this badge from %s recipient(s): %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
new PhutilNumber(count($new)),
|
||||||
|
$handles);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
$new = $this->getNewValue();
|
||||||
|
if (!is_array($new)) {
|
||||||
|
$new = array();
|
||||||
|
}
|
||||||
|
$handles = $this->renderHandleList($new);
|
||||||
|
return pht(
|
||||||
|
'%s revoked %s from %s recipient(s): %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
new PhutilNumber(count($new)),
|
||||||
|
$handles);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-user-times';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
$award_phids = $xaction->getNewValue();
|
||||||
|
if (!$award_phids) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Recipient is required.'));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($award_phids as $award_phid) {
|
||||||
|
$award = id(new PhabricatorBadgesAwardQuery())
|
||||||
|
->setViewer($this->getActor())
|
||||||
|
->withRecipientPHIDs(array($award_phid))
|
||||||
|
->withBadgePHIDs(array($object->getPHID()))
|
||||||
|
->executeOne();
|
||||||
|
if (!$award) {
|
||||||
|
$errors[] = $this->newInvalidError(
|
||||||
|
pht(
|
||||||
|
'Recipient PHID "%s" has not been awarded.',
|
||||||
|
$award_phid));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorBadgesBadgeStatusTransaction
|
||||||
|
extends PhabricatorBadgesBadgeTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'badges.status';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getStatus();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setStatus($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
if ($this->getNewValue() == PhabricatorBadgesBadge::STATUS_ARCHIVED) {
|
||||||
|
return pht(
|
||||||
|
'%s disabled this badge.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s enabled this badge.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
if ($this->getNewValue() == PhabricatorBadgesBadge::STATUS_ARCHIVED) {
|
||||||
|
return pht(
|
||||||
|
'%s disabled the badge %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
} else {
|
||||||
|
return pht(
|
||||||
|
'%s enabled the badge %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
if ($this->getNewValue() == PhabricatorBadgesBadge::STATUS_ARCHIVED) {
|
||||||
|
return 'fa-ban';
|
||||||
|
} else {
|
||||||
|
return 'fa-check';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
abstract class PhabricatorBadgesBadgeTransactionType
|
||||||
|
extends PhabricatorModularTransactionType {}
|
|
@ -11,6 +11,10 @@ final class PhabricatorCalendarExportSearchEngine
|
||||||
return 'PhabricatorCalendarApplication';
|
return 'PhabricatorCalendarApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
$viewer = $this->requireViewer();
|
$viewer = $this->requireViewer();
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorCalendarImportLogSearchEngine
|
||||||
return 'PhabricatorCalendarApplication';
|
return 'PhabricatorCalendarApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorCalendarImportLogQuery();
|
return new PhabricatorCalendarImportLogQuery();
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorCalendarImportSearchEngine
|
||||||
return 'PhabricatorCalendarApplication';
|
return 'PhabricatorCalendarApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorCalendarImportQuery();
|
return new PhabricatorCalendarImportQuery();
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ final class CalendarTimeUtil extends Phobject {
|
||||||
|
|
||||||
$today_epoch = PhabricatorTime::parseLocalTime('today', $user);
|
$today_epoch = PhabricatorTime::parseLocalTime('today', $user);
|
||||||
$today = new DateTime('@'.$today_epoch);
|
$today = new DateTime('@'.$today_epoch);
|
||||||
$today->setTimeZone($timezone);
|
$today->setTimezone($timezone);
|
||||||
|
|
||||||
if (strtolower($start_day_str) == 'today' ||
|
if (strtolower($start_day_str) == 'today' ||
|
||||||
$today->format('l') == $start_day_str) {
|
$today->format('l') == $start_day_str) {
|
||||||
|
@ -79,7 +79,7 @@ final class CalendarTimeUtil extends Phobject {
|
||||||
'last '.$start_day_str,
|
'last '.$start_day_str,
|
||||||
$user);
|
$user);
|
||||||
$start_day = new DateTime('@'.$start_epoch);
|
$start_day = new DateTime('@'.$start_epoch);
|
||||||
$start_day->setTimeZone($timezone);
|
$start_day->setTimezone($timezone);
|
||||||
}
|
}
|
||||||
return array(
|
return array(
|
||||||
'today' => $today,
|
'today' => $today,
|
||||||
|
|
|
@ -193,10 +193,10 @@ final class CelerityDefaultPostprocessor
|
||||||
'sh-disabledbackground' => '#f3f3f3',
|
'sh-disabledbackground' => '#f3f3f3',
|
||||||
|
|
||||||
// Diffs
|
// Diffs
|
||||||
'new-background' => '#eaffea',
|
'new-background' => 'rgba(151, 234, 151, .3)',
|
||||||
'new-bright' => '#a6f3a6',
|
'new-bright' => 'rgba(151, 234, 151, .6)',
|
||||||
'old-background' => '#ffecec',
|
'old-background' => 'rgba(251, 175, 175, .3)',
|
||||||
'old-bright' => '#f8cbcb',
|
'old-bright' => 'rgba(251, 175, 175, .7)',
|
||||||
'move-background' => '#fdf5d4',
|
'move-background' => '#fdf5d4',
|
||||||
'copy-background' => '#f1c40f',
|
'copy-background' => '#f1c40f',
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,23 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class CelerityRedGreenPostprocessor
|
||||||
|
extends CelerityPostprocessor {
|
||||||
|
|
||||||
|
public function getPostprocessorKey() {
|
||||||
|
return 'redgreen';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPostprocessorName() {
|
||||||
|
return pht('Use Red/Green (Deuteranopia) Colors');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildVariables() {
|
||||||
|
return array(
|
||||||
|
'new-background' => 'rgba(152, 207, 235, .15)',
|
||||||
|
'new-bright' => 'rgba(152, 207, 235, .35)',
|
||||||
|
'old-background' => 'rgba(250, 212, 175, .3)',
|
||||||
|
'old-bright' => 'rgba(250, 212, 175, .55)',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -11,6 +11,10 @@ final class PhabricatorConduitLogSearchEngine
|
||||||
return 'PhabricatorConduitApplication';
|
return 'PhabricatorConduitApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorConduitLogQuery();
|
return new PhabricatorConduitLogQuery();
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorConduitSearchEngine
|
||||||
return 'PhabricatorConduitApplication';
|
return 'PhabricatorConduitApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function getPageSize(PhabricatorSavedQuery $saved) {
|
public function getPageSize(PhabricatorSavedQuery $saved) {
|
||||||
return PHP_INT_MAX - 1;
|
return PHP_INT_MAX - 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ final class PhabricatorDaemonsSetupCheck extends PhabricatorSetupCheck {
|
||||||
|
|
||||||
$task_daemon = id(new PhabricatorDaemonLogQuery())
|
$task_daemon = id(new PhabricatorDaemonLogQuery())
|
||||||
->setViewer(PhabricatorUser::getOmnipotentUser())
|
->setViewer(PhabricatorUser::getOmnipotentUser())
|
||||||
->withStatus(PhabricatorDaemonLogQuery::STATUS_RUNNING)
|
->withStatus(PhabricatorDaemonLogQuery::STATUS_ALIVE)
|
||||||
->withDaemonClasses(array('PhabricatorTaskmasterDaemon'))
|
->withDaemonClasses(array('PhabricatorTaskmasterDaemon'))
|
||||||
->setLimit(1)
|
->setLimit(1)
|
||||||
->execute();
|
->execute();
|
||||||
|
|
|
@ -4,7 +4,7 @@ final class ConpherenceThreadSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Rooms');
|
return pht('Conpherence Rooms');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
|
|
|
@ -28,10 +28,6 @@ final class PhabricatorDaemonManagementDebugWorkflow
|
||||||
'instead of the configured %s',
|
'instead of the configured %s',
|
||||||
'phd.user'),
|
'phd.user'),
|
||||||
),
|
),
|
||||||
array(
|
|
||||||
'name' => 'autoscale',
|
|
||||||
'help' => pht('Put the daemon in an autoscale group.'),
|
|
||||||
),
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,16 +40,11 @@ final class PhabricatorDaemonManagementDebugWorkflow
|
||||||
pht('You must specify which daemon to debug.'));
|
pht('You must specify which daemon to debug.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
$config = array();
|
$config = array(
|
||||||
|
'class' => array_shift($argv),
|
||||||
$config['class'] = array_shift($argv);
|
'label' => 'debug',
|
||||||
$config['argv'] = $argv;
|
'argv' => $argv,
|
||||||
|
);
|
||||||
if ($args->getArg('autoscale')) {
|
|
||||||
$config['autoscale'] = array(
|
|
||||||
'group' => 'debug',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->launchDaemons(
|
return $this->launchDaemons(
|
||||||
array(
|
array(
|
||||||
|
|
|
@ -47,7 +47,7 @@ final class PhabricatorDaemonManagementRestartWorkflow
|
||||||
|
|
||||||
return $this->executeStartCommand(
|
return $this->executeStartCommand(
|
||||||
array(
|
array(
|
||||||
'reserve' => (float)$args->getArg('autoscale-reserve', 0.0),
|
'reserve' => (float)$args->getArg('autoscale-reserve'),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,7 @@ final class PhabricatorDaemonManagementStartWorkflow
|
||||||
array(
|
array(
|
||||||
'keep-leases' => $args->getArg('keep-leases'),
|
'keep-leases' => $args->getArg('keep-leases'),
|
||||||
'force' => $args->getArg('force'),
|
'force' => $args->getArg('force'),
|
||||||
'reserve' => (float)$args->getArg('autoscale-reserve', 0.0),
|
'reserve' => (float)$args->getArg('autoscale-reserve'),
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -362,17 +362,17 @@ abstract class PhabricatorDaemonManagementWorkflow
|
||||||
$daemons = array(
|
$daemons = array(
|
||||||
array(
|
array(
|
||||||
'class' => 'PhabricatorRepositoryPullLocalDaemon',
|
'class' => 'PhabricatorRepositoryPullLocalDaemon',
|
||||||
|
'label' => 'pull',
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'class' => 'PhabricatorTriggerDaemon',
|
'class' => 'PhabricatorTriggerDaemon',
|
||||||
|
'label' => 'trigger',
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'class' => 'PhabricatorTaskmasterDaemon',
|
'class' => 'PhabricatorTaskmasterDaemon',
|
||||||
'autoscale' => array(
|
'label' => 'task',
|
||||||
'group' => 'task',
|
'pool' => PhabricatorEnv::getEnvConfig('phd.taskmasters'),
|
||||||
'pool' => PhabricatorEnv::getEnvConfig('phd.taskmasters'),
|
'reserve' => idx($options, 'reserve', 0),
|
||||||
'reserve' => idx($options, 'reserve', 0),
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -618,23 +618,12 @@ abstract class PhabricatorDaemonManagementWorkflow
|
||||||
pht('(Logs will appear in "%s".)', $log_dir));
|
pht('(Logs will appear in "%s".)', $log_dir));
|
||||||
|
|
||||||
foreach ($daemons as $daemon) {
|
foreach ($daemons as $daemon) {
|
||||||
$is_autoscale = isset($daemon['autoscale']['group']);
|
$pool_size = pht('(Pool: %s)', idx($daemon, 'pool', 1));
|
||||||
if ($is_autoscale) {
|
|
||||||
$autoscale = $daemon['autoscale'];
|
|
||||||
foreach ($autoscale as $key => $value) {
|
|
||||||
$autoscale[$key] = $key.'='.$value;
|
|
||||||
}
|
|
||||||
$autoscale = implode(', ', $autoscale);
|
|
||||||
|
|
||||||
$autoscale = pht('(Autoscaling: %s)', $autoscale);
|
|
||||||
} else {
|
|
||||||
$autoscale = pht('(Static)');
|
|
||||||
}
|
|
||||||
|
|
||||||
$console->writeOut(
|
$console->writeOut(
|
||||||
" %s %s\n",
|
" %s %s\n",
|
||||||
|
$pool_size,
|
||||||
$daemon['class'],
|
$daemon['class'],
|
||||||
$autoscale,
|
|
||||||
implode(' ', idx($daemon, 'argv', array())));
|
implode(' ', idx($daemon, 'argv', array())));
|
||||||
}
|
}
|
||||||
$console->writeOut("\n");
|
$console->writeOut("\n");
|
||||||
|
|
|
@ -193,19 +193,23 @@ final class PhabricatorDashboardPanelEditController
|
||||||
->setLabel(pht('Name'))
|
->setLabel(pht('Name'))
|
||||||
->setName('name')
|
->setName('name')
|
||||||
->setValue($v_name)
|
->setValue($v_name)
|
||||||
->setError($e_name))
|
->setError($e_name));
|
||||||
->appendChild(
|
|
||||||
id(new AphrontFormPolicyControl())
|
if (!$request->isAjax() || !$is_create) {
|
||||||
->setName('viewPolicy')
|
$form
|
||||||
->setPolicyObject($panel)
|
->appendChild(
|
||||||
->setCapability(PhabricatorPolicyCapability::CAN_VIEW)
|
id(new AphrontFormPolicyControl())
|
||||||
->setPolicies($policies))
|
->setName('viewPolicy')
|
||||||
->appendChild(
|
->setPolicyObject($panel)
|
||||||
id(new AphrontFormPolicyControl())
|
->setCapability(PhabricatorPolicyCapability::CAN_VIEW)
|
||||||
->setName('editPolicy')
|
->setPolicies($policies))
|
||||||
->setPolicyObject($panel)
|
->appendChild(
|
||||||
->setCapability(PhabricatorPolicyCapability::CAN_EDIT)
|
id(new AphrontFormPolicyControl())
|
||||||
->setPolicies($policies));
|
->setName('editPolicy')
|
||||||
|
->setPolicyObject($panel)
|
||||||
|
->setCapability(PhabricatorPolicyCapability::CAN_EDIT)
|
||||||
|
->setPolicies($policies));
|
||||||
|
}
|
||||||
|
|
||||||
$field_list->appendFieldsToForm($form);
|
$field_list->appendFieldsToForm($form);
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorDashboardPanelSearchEngine
|
||||||
return new PhabricatorDashboardPanelQuery();
|
return new PhabricatorDashboardPanelQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
if ($map['status']) {
|
if ($map['status']) {
|
||||||
|
|
|
@ -16,6 +16,10 @@ final class PhabricatorDashboardSearchEngine
|
||||||
->needPanels(true);
|
->needPanels(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildCustomSearchFields() {
|
protected function buildCustomSearchFields() {
|
||||||
return array(
|
return array(
|
||||||
id(new PhabricatorSearchTextField())
|
id(new PhabricatorSearchTextField())
|
||||||
|
|
|
@ -32,7 +32,7 @@ final class PhabricatorDashboard extends PhabricatorDashboardDAO
|
||||||
return id(new PhabricatorDashboard())
|
return id(new PhabricatorDashboard())
|
||||||
->setName('')
|
->setName('')
|
||||||
->setIcon('fa-dashboard')
|
->setIcon('fa-dashboard')
|
||||||
->setViewPolicy(PhabricatorPolicies::POLICY_USER)
|
->setViewPolicy(PhabricatorPolicies::getMostOpenPolicy())
|
||||||
->setEditPolicy($actor->getPHID())
|
->setEditPolicy($actor->getPHID())
|
||||||
->setStatus(self::STATUS_ACTIVE)
|
->setStatus(self::STATUS_ACTIVE)
|
||||||
->setAuthorPHID($actor->getPHID())
|
->setAuthorPHID($actor->getPHID())
|
||||||
|
|
|
@ -27,7 +27,7 @@ final class PhabricatorDashboardPanel
|
||||||
return id(new PhabricatorDashboardPanel())
|
return id(new PhabricatorDashboardPanel())
|
||||||
->setName('')
|
->setName('')
|
||||||
->setAuthorPHID($actor->getPHID())
|
->setAuthorPHID($actor->getPHID())
|
||||||
->setViewPolicy(PhabricatorPolicies::POLICY_USER)
|
->setViewPolicy(PhabricatorPolicies::getMostOpenPolicy())
|
||||||
->setEditPolicy($actor->getPHID());
|
->setEditPolicy($actor->getPHID());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -51,6 +51,10 @@ final class DifferentialChangesetOneUpMailRenderer
|
||||||
protected function renderPrimitives(array $primitives, $rows) {
|
protected function renderPrimitives(array $primitives, $rows) {
|
||||||
$out = array();
|
$out = array();
|
||||||
|
|
||||||
|
$viewer = $this->getUser();
|
||||||
|
$old_bright = $viewer->getCSSValue('old-bright');
|
||||||
|
$new_bright = $viewer->getCSSValue('new-bright');
|
||||||
|
|
||||||
$context_style = array(
|
$context_style = array(
|
||||||
'background: #F7F7F7;',
|
'background: #F7F7F7;',
|
||||||
'color: #74777D;',
|
'color: #74777D;',
|
||||||
|
@ -72,13 +76,13 @@ final class DifferentialChangesetOneUpMailRenderer
|
||||||
|
|
||||||
if ($is_old) {
|
if ($is_old) {
|
||||||
if ($p['htype']) {
|
if ($p['htype']) {
|
||||||
$style = 'background: #ffd0d0;';
|
$style = "background: {$old_bright};";
|
||||||
} else {
|
} else {
|
||||||
$style = null;
|
$style = null;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ($p['htype']) {
|
if ($p['htype']) {
|
||||||
$style = 'background: #d0ffd0;';
|
$style = "background: {$new_bright};";
|
||||||
} else {
|
} else {
|
||||||
$style = null;
|
$style = null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,7 +52,7 @@ final class DiffusionBrowseQueryConduitAPIMethod
|
||||||
$commit,
|
$commit,
|
||||||
$path);
|
$path);
|
||||||
} catch (CommandException $e) {
|
} catch (CommandException $e) {
|
||||||
$stderr = $e->getStdErr();
|
$stderr = $e->getStderr();
|
||||||
if (preg_match('/^fatal: Not a valid object name/', $stderr)) {
|
if (preg_match('/^fatal: Not a valid object name/', $stderr)) {
|
||||||
// Grab two logs, since the first one is when the object was deleted.
|
// Grab two logs, since the first one is when the object was deleted.
|
||||||
list($stdout) = $repository->execxLocalCommand(
|
list($stdout) = $repository->execxLocalCommand(
|
||||||
|
|
|
@ -446,7 +446,7 @@ final class DiffusionRepositoryController extends DiffusionController {
|
||||||
$header->setHeader(pht('Branches'));
|
$header->setHeader(pht('Branches'));
|
||||||
|
|
||||||
if ($more_branches) {
|
if ($more_branches) {
|
||||||
$header->setSubHeader(pht('Showing %d branches.', $limit));
|
$header->setSubheader(pht('Showing %d branches.', $limit));
|
||||||
}
|
}
|
||||||
|
|
||||||
$button = new PHUIButtonView();
|
$button = new PHUIButtonView();
|
||||||
|
@ -505,7 +505,7 @@ final class DiffusionRepositoryController extends DiffusionController {
|
||||||
$header->setHeader(pht('Tags'));
|
$header->setHeader(pht('Tags'));
|
||||||
|
|
||||||
if ($more_tags) {
|
if ($more_tags) {
|
||||||
$header->setSubHeader(
|
$header->setSubheader(
|
||||||
pht('Showing the %d most recent tags.', $tag_limit));
|
pht('Showing the %d most recent tags.', $tag_limit));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -111,7 +111,6 @@ final class DiffusionCommitEditEngine
|
||||||
->setValue($object->getAuditorPHIDsForEdit());
|
->setValue($object->getAuditorPHIDsForEdit());
|
||||||
|
|
||||||
$reason = $data->getCommitDetail('autocloseReason', false);
|
$reason = $data->getCommitDetail('autocloseReason', false);
|
||||||
$reason = PhabricatorRepository::BECAUSE_AUTOCLOSE_FORCED;
|
|
||||||
if ($reason !== false) {
|
if ($reason !== false) {
|
||||||
switch ($reason) {
|
switch ($reason) {
|
||||||
case PhabricatorRepository::BECAUSE_REPOSITORY_IMPORTING:
|
case PhabricatorRepository::BECAUSE_REPOSITORY_IMPORTING:
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
abstract class DiffusionAuditorsHeraldAction
|
abstract class DiffusionAuditorsHeraldAction
|
||||||
extends HeraldAction {
|
extends HeraldAction {
|
||||||
|
|
||||||
|
const DO_AUTHORS = 'do.authors';
|
||||||
const DO_ADD_AUDITORS = 'do.add-auditors';
|
const DO_ADD_AUDITORS = 'do.add-auditors';
|
||||||
|
|
||||||
public function getActionGroupKey() {
|
public function getActionGroupKey() {
|
||||||
|
@ -19,6 +20,22 @@ abstract class DiffusionAuditorsHeraldAction
|
||||||
|
|
||||||
$auditors = $object->getAudits();
|
$auditors = $object->getAudits();
|
||||||
|
|
||||||
|
// Don't try to add commit authors as auditors.
|
||||||
|
$authors = array();
|
||||||
|
foreach ($phids as $key => $phid) {
|
||||||
|
if ($phid == $object->getAuthorPHID()) {
|
||||||
|
$authors[] = $phid;
|
||||||
|
unset($phids[$key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($authors) {
|
||||||
|
$this->logEffect(self::DO_AUTHORS, $authors);
|
||||||
|
if (!$phids) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$current = array();
|
$current = array();
|
||||||
foreach ($auditors as $auditor) {
|
foreach ($auditors as $auditor) {
|
||||||
if ($auditor->isInteresting()) {
|
if ($auditor->isInteresting()) {
|
||||||
|
@ -53,6 +70,11 @@ abstract class DiffusionAuditorsHeraldAction
|
||||||
|
|
||||||
protected function getActionEffectMap() {
|
protected function getActionEffectMap() {
|
||||||
return array(
|
return array(
|
||||||
|
self::DO_AUTHORS => array(
|
||||||
|
'icon' => 'fa-user',
|
||||||
|
'color' => 'grey',
|
||||||
|
'name' => pht('Commit Author'),
|
||||||
|
),
|
||||||
self::DO_ADD_AUDITORS => array(
|
self::DO_ADD_AUDITORS => array(
|
||||||
'icon' => 'fa-user',
|
'icon' => 'fa-user',
|
||||||
'color' => 'green',
|
'color' => 'green',
|
||||||
|
@ -63,6 +85,10 @@ abstract class DiffusionAuditorsHeraldAction
|
||||||
|
|
||||||
protected function renderActionEffectDescription($type, $data) {
|
protected function renderActionEffectDescription($type, $data) {
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
|
case self::DO_AUTHORS:
|
||||||
|
return pht(
|
||||||
|
'Declined to add commit author as auditor: %s.',
|
||||||
|
$this->renderHandleList($data));
|
||||||
case self::DO_ADD_AUDITORS:
|
case self::DO_ADD_AUDITORS:
|
||||||
return pht(
|
return pht(
|
||||||
'Added %s auditor(s): %s.',
|
'Added %s auditor(s): %s.',
|
||||||
|
|
|
@ -46,7 +46,7 @@ final class HeraldPreCommitContentAdapter extends HeraldPreCommitAdapter {
|
||||||
|
|
||||||
if ($this->changesets instanceof Exception) {
|
if ($this->changesets instanceof Exception) {
|
||||||
$ex_class = get_class($this->changesets);
|
$ex_class = get_class($this->changesets);
|
||||||
$ex_message = $this->changesets->getmessage();
|
$ex_message = $this->changesets->getMessage();
|
||||||
if ($type === 'name') {
|
if ($type === 'name') {
|
||||||
return array("<{$ex_class}: {$ex_message}>");
|
return array("<{$ex_class}: {$ex_message}>");
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -271,13 +271,13 @@ final class DiffusionLowLevelResolveRefsQuery
|
||||||
try {
|
try {
|
||||||
list($stdout) = $future->resolvex();
|
list($stdout) = $future->resolvex();
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
if (preg_match('/ambiguous identifier/', $ex->getStdErr())) {
|
if (preg_match('/ambiguous identifier/', $ex->getStderr())) {
|
||||||
// This indicates that the ref ambiguously matched several things.
|
// This indicates that the ref ambiguously matched several things.
|
||||||
// Eventually, it would be nice to return all of them, but it is
|
// Eventually, it would be nice to return all of them, but it is
|
||||||
// unclear how to best do that. For now, treat it as a miss instead.
|
// unclear how to best do that. For now, treat it as a miss instead.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (preg_match('/unknown revision/', $ex->getStdErr())) {
|
if (preg_match('/unknown revision/', $ex->getStderr())) {
|
||||||
// No matches for this ref.
|
// No matches for this ref.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,6 +58,31 @@ final class DiffusionCommitAuditorsTransaction
|
||||||
return ($old !== $new);
|
return ($old !== $new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function mergeTransactions(
|
||||||
|
$object,
|
||||||
|
PhabricatorApplicationTransaction $u,
|
||||||
|
PhabricatorApplicationTransaction $v) {
|
||||||
|
|
||||||
|
$u_new = $u->getNewValue();
|
||||||
|
$v_new = $v->getNewValue();
|
||||||
|
|
||||||
|
$result = $v_new;
|
||||||
|
foreach (array('-', '+') as $key) {
|
||||||
|
$u_value = idx($u_new, $key, array());
|
||||||
|
$v_value = idx($v_new, $key, array());
|
||||||
|
|
||||||
|
$merged = $u_value + $v_value;
|
||||||
|
|
||||||
|
if ($merged) {
|
||||||
|
$result[$key] = $merged;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$u->setNewValue($result);
|
||||||
|
|
||||||
|
return $u;
|
||||||
|
}
|
||||||
|
|
||||||
public function applyExternalEffects($object, $value) {
|
public function applyExternalEffects($object, $value) {
|
||||||
$src_phid = $object->getPHID();
|
$src_phid = $object->getPHID();
|
||||||
|
|
||||||
|
|
|
@ -128,7 +128,7 @@ final class DivinerPHPAtomizer extends DivinerAtomizer {
|
||||||
|
|
||||||
private function parseParams(DivinerAtom $atom, AASTNode $func) {
|
private function parseParams(DivinerAtom $atom, AASTNode $func) {
|
||||||
$params = $func
|
$params = $func
|
||||||
->getChildByIndex(3, 'n_DECLARATAION_PARAMETER_LIST')
|
->getChildOfType(3, 'n_DECLARATAION_PARAMETER_LIST')
|
||||||
->selectDescendantsOfType('n_DECLARATION_PARAMETER');
|
->selectDescendantsOfType('n_DECLARATION_PARAMETER');
|
||||||
|
|
||||||
$param_spec = array();
|
$param_spec = array();
|
||||||
|
|
|
@ -10,6 +10,10 @@ final class DivinerAtomSearchEngine extends PhabricatorApplicationSearchEngine {
|
||||||
return 'PhabricatorDivinerApplication';
|
return 'PhabricatorDivinerApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
$saved = new PhabricatorSavedQuery();
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorFileSearchEngine
|
||||||
return 'PhabricatorFilesApplication';
|
return 'PhabricatorFilesApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorFileQuery();
|
return new PhabricatorFileQuery();
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class HeraldTranscriptSearchEngine
|
||||||
return 'PhabricatorHeraldApplication';
|
return 'PhabricatorHeraldApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
$saved = new PhabricatorSavedQuery();
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ final class ManiphestTaskSearchEngine
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Tasks');
|
return pht('Maniphest Tasks');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorMetaMTAMailSearchEngine
|
||||||
return 'PhabricatorMetaMTAApplication';
|
return 'PhabricatorMetaMTAApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorMetaMTAMailQuery();
|
return new PhabricatorMetaMTAMailQuery();
|
||||||
}
|
}
|
||||||
|
|
|
@ -340,6 +340,9 @@ final class PhabricatorMetaMTAMail
|
||||||
return $this->save();
|
return $this->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return this
|
||||||
|
*/
|
||||||
public function save() {
|
public function save() {
|
||||||
if ($this->getID()) {
|
if ($this->getID()) {
|
||||||
return parent::save();
|
return parent::save();
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorOAuthServerClientSearchEngine
|
||||||
return 'PhabricatorOAuthServerApplication';
|
return 'PhabricatorOAuthServerApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return id(new PhabricatorOAuthServerClientQuery());
|
return id(new PhabricatorOAuthServerClientQuery());
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorOwnersPackageSearchEngine
|
||||||
return new PhabricatorOwnersPackageQuery();
|
return new PhabricatorOwnersPackageQuery();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildCustomSearchFields() {
|
protected function buildCustomSearchFields() {
|
||||||
return array(
|
return array(
|
||||||
id(new PhabricatorSearchDatasourceField())
|
id(new PhabricatorSearchDatasourceField())
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorPackagesPackageSearchEngine
|
||||||
return id(new PhabricatorPackagesPackageQuery());
|
return id(new PhabricatorPackagesPackageQuery());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorPackagesPublisherSearchEngine
|
||||||
return id(new PhabricatorPackagesPublisherQuery());
|
return id(new PhabricatorPackagesPublisherQuery());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorPackagesVersionSearchEngine
|
||||||
return id(new PhabricatorPackagesVersionQuery());
|
return id(new PhabricatorPackagesVersionQuery());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
|
|
||||||
|
|
|
@ -64,6 +64,8 @@ final class PhabricatorPeopleApplication extends PhabricatorApplication {
|
||||||
'ldap/' => 'PhabricatorPeopleLdapController',
|
'ldap/' => 'PhabricatorPeopleLdapController',
|
||||||
'editprofile/(?P<id>[1-9]\d*)/' =>
|
'editprofile/(?P<id>[1-9]\d*)/' =>
|
||||||
'PhabricatorPeopleProfileEditController',
|
'PhabricatorPeopleProfileEditController',
|
||||||
|
'badges/(?P<id>[1-9]\d*)/' =>
|
||||||
|
'PhabricatorPeopleProfileBadgesController',
|
||||||
'picture/(?P<id>[1-9]\d*)/' =>
|
'picture/(?P<id>[1-9]\d*)/' =>
|
||||||
'PhabricatorPeopleProfilePictureController',
|
'PhabricatorPeopleProfilePictureController',
|
||||||
'manage/(?P<id>[1-9]\d*)/' =>
|
'manage/(?P<id>[1-9]\d*)/' =>
|
||||||
|
|
|
@ -0,0 +1,137 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPeopleProfileBadgesController
|
||||||
|
extends PhabricatorPeopleProfileController {
|
||||||
|
|
||||||
|
public function handleRequest(AphrontRequest $request) {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
$id = $request->getURIData('id');
|
||||||
|
|
||||||
|
$user = id(new PhabricatorPeopleQuery())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->withIDs(array($id))
|
||||||
|
->needProfile(true)
|
||||||
|
->needProfileImage(true)
|
||||||
|
->needAvailability(true)
|
||||||
|
->needBadges(true)
|
||||||
|
->requireCapabilities(
|
||||||
|
array(
|
||||||
|
PhabricatorPolicyCapability::CAN_VIEW,
|
||||||
|
))
|
||||||
|
->executeOne();
|
||||||
|
if (!$user) {
|
||||||
|
return new Aphront404Response();
|
||||||
|
}
|
||||||
|
|
||||||
|
$class = 'PhabricatorBadgesApplication';
|
||||||
|
if (!PhabricatorApplication::isClassInstalledForViewer($class, $viewer)) {
|
||||||
|
return new Aphront404Response();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->setUser($user);
|
||||||
|
$title = array(pht('Badges'), $user->getUsername());
|
||||||
|
$header = $this->buildProfileHeader();
|
||||||
|
$badges = $this->buildBadgesView($user);
|
||||||
|
|
||||||
|
$crumbs = $this->buildApplicationCrumbs();
|
||||||
|
$crumbs->addTextCrumb(pht('Badges'));
|
||||||
|
$crumbs->setBorder(true);
|
||||||
|
|
||||||
|
$nav = $this->getProfileMenu();
|
||||||
|
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_BADGES);
|
||||||
|
|
||||||
|
// Best option?
|
||||||
|
$badges = id(new PhabricatorBadgesQuery())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->withStatuses(array(
|
||||||
|
PhabricatorBadgesBadge::STATUS_ACTIVE,
|
||||||
|
))
|
||||||
|
->requireCapabilities(
|
||||||
|
array(
|
||||||
|
PhabricatorPolicyCapability::CAN_VIEW,
|
||||||
|
PhabricatorPolicyCapability::CAN_EDIT,
|
||||||
|
))
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
$button = id(new PHUIButtonView())
|
||||||
|
->setTag('a')
|
||||||
|
->setIcon('fa-plus')
|
||||||
|
->setText(pht('Award Badge'))
|
||||||
|
->setWorkflow(true)
|
||||||
|
->setHref('/badges/award/'.$user->getID().'/');
|
||||||
|
|
||||||
|
if (count($badges)) {
|
||||||
|
$header->addActionLink($button);
|
||||||
|
}
|
||||||
|
|
||||||
|
$view = id(new PHUITwoColumnView())
|
||||||
|
->setHeader($header)
|
||||||
|
->addClass('project-view-home')
|
||||||
|
->addClass('project-view-people-home')
|
||||||
|
->setFooter(array(
|
||||||
|
$this->buildBadgesView($user)
|
||||||
|
));
|
||||||
|
|
||||||
|
return $this->newPage()
|
||||||
|
->setTitle($title)
|
||||||
|
->setCrumbs($crumbs)
|
||||||
|
->setNavigation($nav)
|
||||||
|
->appendChild($view);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function buildBadgesView(PhabricatorUser $user) {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
|
||||||
|
$awards = array();
|
||||||
|
$badges = array();
|
||||||
|
if ($user->getBadgePHIDs()) {
|
||||||
|
$awards = id(new PhabricatorBadgesAwardQuery())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->withRecipientPHIDs(array($user->getPHID()))
|
||||||
|
->execute();
|
||||||
|
$awards = mpull($awards, null, 'getBadgePHID');
|
||||||
|
|
||||||
|
$badges = array();
|
||||||
|
foreach ($awards as $award) {
|
||||||
|
$badge = $award->getBadge();
|
||||||
|
if ($badge->getStatus() == PhabricatorBadgesBadge::STATUS_ACTIVE) {
|
||||||
|
$badges[$award->getBadgePHID()] = $badge;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($badges)) {
|
||||||
|
$flex = new PHUIBadgeBoxView();
|
||||||
|
|
||||||
|
foreach ($badges as $badge) {
|
||||||
|
if ($badge) {
|
||||||
|
$awarder_info = array();
|
||||||
|
|
||||||
|
$award = idx($awards, $badge->getPHID(), null);
|
||||||
|
$awarder_phid = $award->getAwarderPHID();
|
||||||
|
$awarder_handle = $viewer->renderHandle($awarder_phid);
|
||||||
|
|
||||||
|
$awarder_info = pht(
|
||||||
|
'Awarded by %s',
|
||||||
|
$awarder_handle->render());
|
||||||
|
|
||||||
|
$item = id(new PHUIBadgeView())
|
||||||
|
->setIcon($badge->getIcon())
|
||||||
|
->setHeader($badge->getName())
|
||||||
|
->setSubhead($badge->getFlavor())
|
||||||
|
->setQuality($badge->getQuality())
|
||||||
|
->setHref($badge->getViewURI())
|
||||||
|
->addByLine($awarder_info);
|
||||||
|
|
||||||
|
$flex->addItem($item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$flex = id(new PHUIInfoView())
|
||||||
|
->setSeverity(PHUIInfoView::SEVERITY_NOTICE)
|
||||||
|
->appendChild(pht('User has not been awarded any badges.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $flex;
|
||||||
|
}
|
||||||
|
}
|
|
@ -86,6 +86,9 @@ abstract class PhabricatorPeopleProfileController
|
||||||
if ($user->getIsMailingList()) {
|
if ($user->getIsMailingList()) {
|
||||||
$roles[] = pht('Mailing List');
|
$roles[] = pht('Mailing List');
|
||||||
}
|
}
|
||||||
|
if (!$user->getIsEmailVerified()) {
|
||||||
|
$roles[] = pht('Email Not Verified');
|
||||||
|
}
|
||||||
|
|
||||||
$tag = null;
|
$tag = null;
|
||||||
if ($roles) {
|
if ($roles) {
|
||||||
|
@ -101,10 +104,10 @@ abstract class PhabricatorPeopleProfileController
|
||||||
->setProfileHeader(true)
|
->setProfileHeader(true)
|
||||||
->addClass('people-profile-header');
|
->addClass('people-profile-header');
|
||||||
|
|
||||||
|
require_celerity_resource('project-view-css');
|
||||||
|
|
||||||
if ($user->getIsDisabled()) {
|
if ($user->getIsDisabled()) {
|
||||||
$header->setStatus('fa-ban', 'red', pht('Disabled'));
|
$header->setStatus('fa-ban', 'red', pht('Disabled'));
|
||||||
} else if (!$user->getIsEmailVerified()) {
|
|
||||||
$header->setStatus('fa-envelope', 'red', pht('Email Not Verified'));
|
|
||||||
} else {
|
} else {
|
||||||
$header->setStatus($profile_icon, 'bluegrey', $profile_title);
|
$header->setStatus($profile_icon, 'bluegrey', $profile_title);
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,9 +39,9 @@ final class PhabricatorPeopleProfileManageController
|
||||||
$manage = id(new PHUITwoColumnView())
|
$manage = id(new PHUITwoColumnView())
|
||||||
->setHeader($header)
|
->setHeader($header)
|
||||||
->addClass('project-view-home')
|
->addClass('project-view-home')
|
||||||
|
->addClass('project-view-people-home')
|
||||||
->setCurtain($curtain)
|
->setCurtain($curtain)
|
||||||
->addPropertySection(pht('Details'), $properties);
|
->addPropertySection(pht('Details'), $properties);
|
||||||
require_celerity_resource('project-view-css');
|
|
||||||
|
|
||||||
return $this->newPage()
|
return $this->newPage()
|
||||||
->setTitle(
|
->setTitle(
|
||||||
|
|
|
@ -258,12 +258,12 @@ final class PhabricatorPeopleProfilePictureController
|
||||||
$nav = $this->getProfileMenu();
|
$nav = $this->getProfileMenu();
|
||||||
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_MANAGE);
|
$nav->selectFilter(PhabricatorPeopleProfileMenuEngine::ITEM_MANAGE);
|
||||||
|
|
||||||
$header = id(new PHUIHeaderView())
|
$header = $this->buildProfileHeader();
|
||||||
->setHeader(pht('Edit Profile Picture'))
|
|
||||||
->setHeaderIcon('fa-camera');
|
|
||||||
|
|
||||||
$view = id(new PHUITwoColumnView())
|
$view = id(new PHUITwoColumnView())
|
||||||
->setHeader($header)
|
->setHeader($header)
|
||||||
|
->addClass('project-view-home')
|
||||||
|
->addClass('project-view-people-home')
|
||||||
->setFooter(array(
|
->setFooter(array(
|
||||||
$form_box,
|
$form_box,
|
||||||
$upload_box,
|
$upload_box,
|
||||||
|
|
|
@ -14,7 +14,6 @@ final class PhabricatorPeopleProfileViewController
|
||||||
$user = id(new PhabricatorPeopleQuery())
|
$user = id(new PhabricatorPeopleQuery())
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
->withUsernames(array($username))
|
->withUsernames(array($username))
|
||||||
->needBadges(true)
|
|
||||||
->needProfileImage(true)
|
->needProfileImage(true)
|
||||||
->needAvailability(true)
|
->needAvailability(true)
|
||||||
->executeOne();
|
->executeOne();
|
||||||
|
@ -36,8 +35,6 @@ final class PhabricatorPeopleProfileViewController
|
||||||
|
|
||||||
$projects = $this->buildProjectsView($user);
|
$projects = $this->buildProjectsView($user);
|
||||||
$calendar = $this->buildCalendarDayView($user);
|
$calendar = $this->buildCalendarDayView($user);
|
||||||
$badges = $this->buildBadgesView($user);
|
|
||||||
require_celerity_resource('project-view-css');
|
|
||||||
|
|
||||||
$home = id(new PHUITwoColumnView())
|
$home = id(new PHUITwoColumnView())
|
||||||
->setHeader($header)
|
->setHeader($header)
|
||||||
|
@ -52,7 +49,6 @@ final class PhabricatorPeopleProfileViewController
|
||||||
array(
|
array(
|
||||||
$projects,
|
$projects,
|
||||||
$calendar,
|
$calendar,
|
||||||
$badges,
|
|
||||||
));
|
));
|
||||||
|
|
||||||
$nav = $this->getProfileMenu();
|
$nav = $this->getProfileMenu();
|
||||||
|
@ -228,106 +224,6 @@ final class PhabricatorPeopleProfileViewController
|
||||||
return $box;
|
return $box;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function buildBadgesView(PhabricatorUser $user) {
|
|
||||||
|
|
||||||
$viewer = $this->getViewer();
|
|
||||||
$class = 'PhabricatorBadgesApplication';
|
|
||||||
|
|
||||||
if (!PhabricatorApplication::isClassInstalledForViewer($class, $viewer)) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$awards = array();
|
|
||||||
$badges = array();
|
|
||||||
if ($user->getBadgePHIDs()) {
|
|
||||||
$awards = id(new PhabricatorBadgesAwardQuery())
|
|
||||||
->setViewer($viewer)
|
|
||||||
->withRecipientPHIDs(array($user->getPHID()))
|
|
||||||
->execute();
|
|
||||||
$awards = mpull($awards, null, 'getBadgePHID');
|
|
||||||
|
|
||||||
$badges = array();
|
|
||||||
foreach ($awards as $award) {
|
|
||||||
$badge = $award->getBadge();
|
|
||||||
if ($badge->getStatus() == PhabricatorBadgesBadge::STATUS_ACTIVE) {
|
|
||||||
$badges[$award->getBadgePHID()] = $badge;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count($badges)) {
|
|
||||||
$flex = new PHUIBadgeBoxView();
|
|
||||||
|
|
||||||
foreach ($badges as $badge) {
|
|
||||||
if ($badge) {
|
|
||||||
$awarder_info = array();
|
|
||||||
|
|
||||||
$award = idx($awards, $badge->getPHID(), null);
|
|
||||||
$awarder_phid = $award->getAwarderPHID();
|
|
||||||
$awarder_handle = $viewer->renderHandle($awarder_phid);
|
|
||||||
|
|
||||||
$awarder_info = pht(
|
|
||||||
'Awarded by %s',
|
|
||||||
$awarder_handle->render());
|
|
||||||
|
|
||||||
$item = id(new PHUIBadgeView())
|
|
||||||
->setIcon($badge->getIcon())
|
|
||||||
->setHeader($badge->getName())
|
|
||||||
->setSubhead($badge->getFlavor())
|
|
||||||
->setQuality($badge->getQuality())
|
|
||||||
->setHref($badge->getViewURI())
|
|
||||||
->addByLine($awarder_info);
|
|
||||||
|
|
||||||
$flex->addItem($item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$flex = id(new PHUIInfoView())
|
|
||||||
->setSeverity(PHUIInfoView::SEVERITY_NODATA)
|
|
||||||
->appendChild(pht('User does not have any badges.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Best option?
|
|
||||||
$badges = id(new PhabricatorBadgesQuery())
|
|
||||||
->setViewer($viewer)
|
|
||||||
->withStatuses(array(
|
|
||||||
PhabricatorBadgesBadge::STATUS_ACTIVE,
|
|
||||||
))
|
|
||||||
->requireCapabilities(
|
|
||||||
array(
|
|
||||||
PhabricatorPolicyCapability::CAN_VIEW,
|
|
||||||
PhabricatorPolicyCapability::CAN_EDIT,
|
|
||||||
))
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
$button = id(new PHUIButtonView())
|
|
||||||
->setTag('a')
|
|
||||||
->setIcon('fa-plus')
|
|
||||||
->setText(pht('Award'))
|
|
||||||
->setWorkflow(true)
|
|
||||||
->setHref('/badges/award/'.$user->getID().'/');
|
|
||||||
|
|
||||||
$can_award = false;
|
|
||||||
if (count($badges)) {
|
|
||||||
$can_award = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
$header = id(new PHUIHeaderView())
|
|
||||||
->setHeader(pht('Badges'));
|
|
||||||
|
|
||||||
if (count($badges)) {
|
|
||||||
$header->addActionLink($button);
|
|
||||||
}
|
|
||||||
|
|
||||||
$box = id(new PHUIObjectBoxView())
|
|
||||||
->setHeader($header)
|
|
||||||
->addClass('project-view-badges')
|
|
||||||
->appendChild($flex)
|
|
||||||
->setBackground(PHUIObjectBoxView::BLUE_PROPERTY);
|
|
||||||
|
|
||||||
return $box;
|
|
||||||
}
|
|
||||||
|
|
||||||
private function buildPeopleFeed(
|
private function buildPeopleFeed(
|
||||||
PhabricatorUser $user,
|
PhabricatorUser $user,
|
||||||
$viewer) {
|
$viewer) {
|
||||||
|
|
|
@ -6,6 +6,7 @@ final class PhabricatorPeopleProfileMenuEngine
|
||||||
const ITEM_PROFILE = 'people.profile';
|
const ITEM_PROFILE = 'people.profile';
|
||||||
const ITEM_MANAGE = 'people.manage';
|
const ITEM_MANAGE = 'people.manage';
|
||||||
const ITEM_PICTURE = 'people.picture';
|
const ITEM_PICTURE = 'people.picture';
|
||||||
|
const ITEM_BADGES = 'people.badges';
|
||||||
|
|
||||||
protected function isMenuEngineConfigurable() {
|
protected function isMenuEngineConfigurable() {
|
||||||
return false;
|
return false;
|
||||||
|
@ -31,6 +32,15 @@ final class PhabricatorPeopleProfileMenuEngine
|
||||||
->setBuiltinKey(self::ITEM_PROFILE)
|
->setBuiltinKey(self::ITEM_PROFILE)
|
||||||
->setMenuItemKey(PhabricatorPeopleDetailsProfileMenuItem::MENUITEMKEY);
|
->setMenuItemKey(PhabricatorPeopleDetailsProfileMenuItem::MENUITEMKEY);
|
||||||
|
|
||||||
|
$have_badges = PhabricatorApplication::isClassInstalledForViewer(
|
||||||
|
'PhabricatorBadgesApplication',
|
||||||
|
$viewer);
|
||||||
|
if ($have_badges) {
|
||||||
|
$items[] = $this->newItem()
|
||||||
|
->setBuiltinKey(self::ITEM_BADGES)
|
||||||
|
->setMenuItemKey(PhabricatorPeopleBadgesProfileMenuItem::MENUITEMKEY);
|
||||||
|
}
|
||||||
|
|
||||||
$have_maniphest = PhabricatorApplication::isClassInstalledForViewer(
|
$have_maniphest = PhabricatorApplication::isClassInstalledForViewer(
|
||||||
'PhabricatorManiphestApplication',
|
'PhabricatorManiphestApplication',
|
||||||
$viewer);
|
$viewer);
|
||||||
|
|
|
@ -27,7 +27,6 @@ final class PeopleHovercardEngineExtension
|
||||||
->needAvailability(true)
|
->needAvailability(true)
|
||||||
->needProfileImage(true)
|
->needProfileImage(true)
|
||||||
->needProfile(true)
|
->needProfile(true)
|
||||||
->needBadges(true)
|
|
||||||
->execute();
|
->execute();
|
||||||
$users = mpull($users, null, 'getPHID');
|
$users = mpull($users, null, 'getPHID');
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPeopleBadgesProfileMenuItem
|
||||||
|
extends PhabricatorProfileMenuItem {
|
||||||
|
|
||||||
|
const MENUITEMKEY = 'people.badges';
|
||||||
|
|
||||||
|
public function getMenuItemTypeName() {
|
||||||
|
return pht('Badges');
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getDefaultName() {
|
||||||
|
return pht('Badges');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function canHideMenuItem(
|
||||||
|
PhabricatorProfileMenuItemConfiguration $config) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getDisplayName(
|
||||||
|
PhabricatorProfileMenuItemConfiguration $config) {
|
||||||
|
$name = $config->getMenuItemProperty('name');
|
||||||
|
|
||||||
|
if (strlen($name)) {
|
||||||
|
return $name;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this->getDefaultName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function buildEditEngineFields(
|
||||||
|
PhabricatorProfileMenuItemConfiguration $config) {
|
||||||
|
return array(
|
||||||
|
id(new PhabricatorTextEditField())
|
||||||
|
->setKey('name')
|
||||||
|
->setLabel(pht('Name'))
|
||||||
|
->setPlaceholder($this->getDefaultName())
|
||||||
|
->setValue($config->getMenuItemProperty('name')),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function newNavigationMenuItems(
|
||||||
|
PhabricatorProfileMenuItemConfiguration $config) {
|
||||||
|
|
||||||
|
$user = $config->getProfileObject();
|
||||||
|
$id = $user->getID();
|
||||||
|
|
||||||
|
$item = $this->newItem()
|
||||||
|
->setHref("/people/badges/{$id}/")
|
||||||
|
->setName($this->getDisplayName($config))
|
||||||
|
->setIcon('fa-trophy');
|
||||||
|
|
||||||
|
return array(
|
||||||
|
$item,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -36,6 +36,13 @@ final class PhabricatorPeoplePictureProfileMenuItem
|
||||||
|
|
||||||
$picture = $user->getProfileImageURI();
|
$picture = $user->getProfileImageURI();
|
||||||
$name = $user->getUsername();
|
$name = $user->getUsername();
|
||||||
|
|
||||||
|
$classes = array();
|
||||||
|
$classes[] = 'people-menu-image';
|
||||||
|
if ($user->getIsDisabled()) {
|
||||||
|
$classes[] = 'phui-image-disabled';
|
||||||
|
}
|
||||||
|
|
||||||
$href = urisprintf(
|
$href = urisprintf(
|
||||||
'/p/%s/',
|
'/p/%s/',
|
||||||
$user->getUsername());
|
$user->getUsername());
|
||||||
|
@ -44,7 +51,7 @@ final class PhabricatorPeoplePictureProfileMenuItem
|
||||||
'img',
|
'img',
|
||||||
array(
|
array(
|
||||||
'src' => $picture,
|
'src' => $picture,
|
||||||
'class' => 'people-menu-image',
|
'class' => implode(' ', $classes),
|
||||||
));
|
));
|
||||||
|
|
||||||
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
||||||
|
|
|
@ -1580,4 +1580,22 @@ final class PhabricatorUser
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function getCSSValue($variable_key) {
|
||||||
|
$preference = PhabricatorAccessibilitySetting::SETTINGKEY;
|
||||||
|
$key = $this->getUserSetting($preference);
|
||||||
|
|
||||||
|
$postprocessor = CelerityPostprocessor::getPostprocessor($key);
|
||||||
|
$variables = $postprocessor->getVariables();
|
||||||
|
|
||||||
|
if (!isset($variables[$variable_key])) {
|
||||||
|
throw new Exception(
|
||||||
|
pht(
|
||||||
|
'Unknown CSS variable "%s"!',
|
||||||
|
$variable_key));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $variables[$variable_key];
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,9 +33,7 @@ final class PhabricatorUserCardView extends AphrontTagView {
|
||||||
$classes[] = 'project-card-view';
|
$classes[] = 'project-card-view';
|
||||||
|
|
||||||
if ($this->profile->getIsDisabled()) {
|
if ($this->profile->getIsDisabled()) {
|
||||||
$classes[] = 'project-card-grey';
|
$classes[] = 'project-card-disabled';
|
||||||
} else {
|
|
||||||
$classes[] = 'project-card-blue';
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
|
@ -56,10 +54,12 @@ final class PhabricatorUserCardView extends AphrontTagView {
|
||||||
// the most important tag. Users can click through to the profile to get
|
// the most important tag. Users can click through to the profile to get
|
||||||
// more details.
|
// more details.
|
||||||
|
|
||||||
|
$classes = array();
|
||||||
if ($user->getIsDisabled()) {
|
if ($user->getIsDisabled()) {
|
||||||
$tag_icon = 'fa-ban';
|
$tag_icon = 'fa-ban';
|
||||||
$tag_title = pht('Disabled');
|
$tag_title = pht('Disabled');
|
||||||
$tag_shade = PHUITagView::COLOR_RED;
|
$tag_shade = PHUITagView::COLOR_RED;
|
||||||
|
$classes[] = 'phui-image-disabled';
|
||||||
} else if (!$user->getIsApproved()) {
|
} else if (!$user->getIsApproved()) {
|
||||||
$tag_icon = 'fa-ban';
|
$tag_icon = 'fa-ban';
|
||||||
$tag_title = pht('Unapproved Account');
|
$tag_title = pht('Unapproved Account');
|
||||||
|
@ -87,47 +87,60 @@ final class PhabricatorUserCardView extends AphrontTagView {
|
||||||
$tag->setShade($tag_shade);
|
$tag->setShade($tag_shade);
|
||||||
}
|
}
|
||||||
|
|
||||||
$header = id(new PHUIHeaderView())
|
|
||||||
->setHeader($user->getFullName())
|
|
||||||
->addTag($tag)
|
|
||||||
->setUser($viewer)
|
|
||||||
->setImage($picture);
|
|
||||||
|
|
||||||
$body = array();
|
$body = array();
|
||||||
|
|
||||||
|
/* TODO: Replace with Conpherence Availability if we ship it */
|
||||||
$body[] = $this->addItem(
|
$body[] = $this->addItem(
|
||||||
pht('User Since'),
|
'fa-user-plus',
|
||||||
phabricator_date($user->getDateCreated(), $viewer));
|
phabricator_date($user->getDateCreated(), $viewer));
|
||||||
|
|
||||||
if (PhabricatorApplication::isClassInstalledForViewer(
|
if (PhabricatorApplication::isClassInstalledForViewer(
|
||||||
'PhabricatorCalendarApplication',
|
'PhabricatorCalendarApplication',
|
||||||
$viewer)) {
|
$viewer)) {
|
||||||
$body[] = $this->addItem(
|
$body[] = $this->addItem(
|
||||||
pht('Availability'),
|
'fa-calendar-o',
|
||||||
id(new PHUIUserAvailabilityView())
|
id(new PHUIUserAvailabilityView())
|
||||||
->setViewer($viewer)
|
->setViewer($viewer)
|
||||||
->setAvailableUser($user));
|
->setAvailableUser($user));
|
||||||
}
|
}
|
||||||
|
|
||||||
$badges = $this->buildBadges($user, $viewer);
|
$classes[] = 'project-card-image';
|
||||||
if ($badges) {
|
$image = phutil_tag(
|
||||||
$badges = id(new PHUIBadgeBoxView())
|
'img',
|
||||||
->addItems($badges)
|
array(
|
||||||
->setCollapsed(true);
|
'src' => $picture,
|
||||||
$body[] = phutil_tag(
|
'class' => implode(' ', $classes),
|
||||||
'div',
|
));
|
||||||
array(
|
|
||||||
'class' => 'phui-hovercard-body-item hovercard-badges',
|
|
||||||
),
|
|
||||||
$badges);
|
|
||||||
}
|
|
||||||
|
|
||||||
$body = phutil_tag(
|
$href = urisprintf(
|
||||||
|
'/p/%s/',
|
||||||
|
$user->getUsername());
|
||||||
|
|
||||||
|
$image = phutil_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => $href,
|
||||||
|
),
|
||||||
|
$image);
|
||||||
|
|
||||||
|
$name = phutil_tag_div('project-card-name',
|
||||||
|
$user->getRealname());
|
||||||
|
$username = phutil_tag_div('project-card-username',
|
||||||
|
'@'.$user->getUsername());
|
||||||
|
$tag = phutil_tag_div('phui-header-subheader',
|
||||||
|
$tag);
|
||||||
|
|
||||||
|
$header = phutil_tag(
|
||||||
'div',
|
'div',
|
||||||
array(
|
array(
|
||||||
'class' => 'project-card-body',
|
'class' => 'project-card-header',
|
||||||
),
|
),
|
||||||
$body);
|
array(
|
||||||
|
$name,
|
||||||
|
$username,
|
||||||
|
$tag,
|
||||||
|
$body,
|
||||||
|
));
|
||||||
|
|
||||||
$card = phutil_tag(
|
$card = phutil_tag(
|
||||||
'div',
|
'div',
|
||||||
|
@ -135,47 +148,24 @@ final class PhabricatorUserCardView extends AphrontTagView {
|
||||||
'class' => 'project-card-inner',
|
'class' => 'project-card-inner',
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
|
$image,
|
||||||
$header,
|
$header,
|
||||||
$body,
|
|
||||||
));
|
));
|
||||||
|
|
||||||
return $card;
|
return $card;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addItem($label, $value) {
|
private function addItem($icon, $value) {
|
||||||
$item = array(
|
$icon = id(new PHUIIconView())
|
||||||
phutil_tag('strong', array(), $label),
|
->addClass('project-card-item-icon')
|
||||||
': ',
|
->setIcon($icon);
|
||||||
phutil_tag('span', array(), $value),
|
$text = phutil_tag(
|
||||||
);
|
'span',
|
||||||
return phutil_tag_div('project-card-item', $item);
|
array(
|
||||||
}
|
'class' => 'project-card-item-text',
|
||||||
|
),
|
||||||
private function buildBadges(
|
$value);
|
||||||
PhabricatorUser $user,
|
return phutil_tag_div('project-card-item', array($icon, $text));
|
||||||
$viewer) {
|
|
||||||
|
|
||||||
$class = 'PhabricatorBadgesApplication';
|
|
||||||
$items = array();
|
|
||||||
|
|
||||||
if (PhabricatorApplication::isClassInstalledForViewer($class, $viewer)) {
|
|
||||||
$badge_phids = $user->getBadgePHIDs();
|
|
||||||
if ($badge_phids) {
|
|
||||||
$badges = id(new PhabricatorBadgesQuery())
|
|
||||||
->setViewer($viewer)
|
|
||||||
->withPHIDs($badge_phids)
|
|
||||||
->withStatuses(array(PhabricatorBadgesBadge::STATUS_ACTIVE))
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
foreach ($badges as $badge) {
|
|
||||||
$items[] = id(new PHUIBadgeMiniView())
|
|
||||||
->setIcon($badge->getIcon())
|
|
||||||
->setHeader($badge->getName())
|
|
||||||
->setQuality($badge->getQuality());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return $items;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,7 +86,7 @@ final class PhabricatorPhortuneManagementInvoiceWorkflow
|
||||||
|
|
||||||
$auto_range = $args->getArg('auto-range');
|
$auto_range = $args->getArg('auto-range');
|
||||||
$last_arg = $args->getArg('last');
|
$last_arg = $args->getArg('last');
|
||||||
$next_arg = $args->getARg('next');
|
$next_arg = $args->getArg('next');
|
||||||
|
|
||||||
if (!$auto_range && !$last_arg && !$next_arg) {
|
if (!$auto_range && !$last_arg && !$next_arg) {
|
||||||
throw new PhutilArgumentUsageException(
|
throw new PhutilArgumentUsageException(
|
||||||
|
|
|
@ -10,6 +10,11 @@ final class PhrequentSearchEngine extends PhabricatorApplicationSearchEngine {
|
||||||
return 'PhabricatorPhrequentApplication';
|
return 'PhabricatorPhrequentApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getPageSize(PhabricatorSavedQuery $saved) {
|
public function getPageSize(PhabricatorSavedQuery $saved) {
|
||||||
return $saved->getParameter('limit', 1000);
|
return $saved->getParameter('limit', 1000);
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,10 @@ final class PhabricatorPhurlURLEditEngine
|
||||||
return pht('Configure creation and editing forms in Phurl.');
|
return pht('Configure creation and editing forms in Phurl.');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function isEngineConfigurable() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function newEditableObject() {
|
protected function newEditableObject() {
|
||||||
return PhabricatorPhurlURL::initializeNewPhurlURL($this->getViewer());
|
return PhabricatorPhurlURL::initializeNewPhurlURL($this->getViewer());
|
||||||
}
|
}
|
||||||
|
@ -73,8 +77,10 @@ final class PhabricatorPhurlURLEditEngine
|
||||||
->setKey('name')
|
->setKey('name')
|
||||||
->setLabel(pht('Name'))
|
->setLabel(pht('Name'))
|
||||||
->setDescription(pht('URL name.'))
|
->setDescription(pht('URL name.'))
|
||||||
|
->setIsRequired(true)
|
||||||
->setConduitTypeDescription(pht('New URL name.'))
|
->setConduitTypeDescription(pht('New URL name.'))
|
||||||
->setTransactionType(PhabricatorPhurlURLTransaction::TYPE_NAME)
|
->setTransactionType(
|
||||||
|
PhabricatorPhurlURLNameTransaction::TRANSACTIONTYPE)
|
||||||
->setValue($object->getName()),
|
->setValue($object->getName()),
|
||||||
id(new PhabricatorTextEditField())
|
id(new PhabricatorTextEditField())
|
||||||
->setKey('url')
|
->setKey('url')
|
||||||
|
@ -83,11 +89,14 @@ final class PhabricatorPhurlURLEditEngine
|
||||||
->setConduitTypeDescription(pht('New URL.'))
|
->setConduitTypeDescription(pht('New URL.'))
|
||||||
->setValue($object->getLongURL())
|
->setValue($object->getLongURL())
|
||||||
->setIsRequired(true)
|
->setIsRequired(true)
|
||||||
->setTransactionType(PhabricatorPhurlURLTransaction::TYPE_URL),
|
->setTransactionType(
|
||||||
|
PhabricatorPhurlURLLongURLTransaction::TRANSACTIONTYPE),
|
||||||
id(new PhabricatorTextEditField())
|
id(new PhabricatorTextEditField())
|
||||||
->setKey('alias')
|
->setKey('alias')
|
||||||
->setLabel(pht('Alias'))
|
->setLabel(pht('Alias'))
|
||||||
->setTransactionType(PhabricatorPhurlURLTransaction::TYPE_ALIAS)
|
->setIsRequired(true)
|
||||||
|
->setTransactionType(
|
||||||
|
PhabricatorPhurlURLAliasTransaction::TRANSACTIONTYPE)
|
||||||
->setDescription(pht('The alias to give the URL.'))
|
->setDescription(pht('The alias to give the URL.'))
|
||||||
->setConduitTypeDescription(pht('New alias.'))
|
->setConduitTypeDescription(pht('New alias.'))
|
||||||
->setValue($object->getAlias()),
|
->setValue($object->getAlias()),
|
||||||
|
@ -96,7 +105,8 @@ final class PhabricatorPhurlURLEditEngine
|
||||||
->setLabel(pht('Description'))
|
->setLabel(pht('Description'))
|
||||||
->setDescription(pht('URL long description.'))
|
->setDescription(pht('URL long description.'))
|
||||||
->setConduitTypeDescription(pht('New URL description.'))
|
->setConduitTypeDescription(pht('New URL description.'))
|
||||||
->setTransactionType(PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION)
|
->setTransactionType(
|
||||||
|
PhabricatorPhurlURLDescriptionTransaction::TRANSACTIONTYPE)
|
||||||
->setValue($object->getDescription()),
|
->setValue($object->getDescription()),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,14 +11,20 @@ final class PhabricatorPhurlURLEditor
|
||||||
return pht('Phurl');
|
return pht('Phurl');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getCreateObjectTitle($author, $object) {
|
||||||
|
return pht('%s created this URL.', $author);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCreateObjectTitleForFeed($author, $object) {
|
||||||
|
return pht('%s created %s.', $author, $object);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function supportsSearch() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public function getTransactionTypes() {
|
public function getTransactionTypes() {
|
||||||
$types = parent::getTransactionTypes();
|
$types = parent::getTransactionTypes();
|
||||||
|
|
||||||
$types[] = PhabricatorPhurlURLTransaction::TYPE_NAME;
|
|
||||||
$types[] = PhabricatorPhurlURLTransaction::TYPE_URL;
|
|
||||||
$types[] = PhabricatorPhurlURLTransaction::TYPE_ALIAS;
|
|
||||||
$types[] = PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION;
|
|
||||||
|
|
||||||
$types[] = PhabricatorTransactions::TYPE_COMMENT;
|
$types[] = PhabricatorTransactions::TYPE_COMMENT;
|
||||||
$types[] = PhabricatorTransactions::TYPE_VIEW_POLICY;
|
$types[] = PhabricatorTransactions::TYPE_VIEW_POLICY;
|
||||||
$types[] = PhabricatorTransactions::TYPE_EDIT_POLICY;
|
$types[] = PhabricatorTransactions::TYPE_EDIT_POLICY;
|
||||||
|
@ -26,160 +32,18 @@ final class PhabricatorPhurlURLEditor
|
||||||
return $types;
|
return $types;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getCustomTransactionOldValue(
|
protected function shouldSendMail(
|
||||||
PhabricatorLiskDAO $object,
|
PhabricatorLiskDAO $object,
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_NAME:
|
|
||||||
return $object->getName();
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_URL:
|
|
||||||
return $object->getLongURL();
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_ALIAS:
|
|
||||||
return $object->getAlias();
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION:
|
|
||||||
return $object->getDescription();
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getCustomTransactionOldValue($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getCustomTransactionNewValue(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_NAME:
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_URL:
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION:
|
|
||||||
return $xaction->getNewValue();
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_ALIAS:
|
|
||||||
if (!strlen($xaction->getNewValue())) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
return $xaction->getNewValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getCustomTransactionNewValue($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomInternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_NAME:
|
|
||||||
$object->setName($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_URL:
|
|
||||||
$object->setLongURL($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_ALIAS:
|
|
||||||
$object->setAlias($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION:
|
|
||||||
$object->setDescription($xaction->getNewValue());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::applyCustomInternalTransaction($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function applyCustomExternalTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
|
||||||
|
|
||||||
switch ($xaction->getTransactionType()) {
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_NAME:
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_URL:
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_ALIAS:
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_DESCRIPTION:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::applyCustomExternalTransaction($object, $xaction);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function validateTransaction(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
$type,
|
|
||||||
array $xactions) {
|
array $xactions) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
$errors = parent::validateTransaction($object, $type, $xactions);
|
public function getMailTagsMap() {
|
||||||
|
return array(
|
||||||
switch ($type) {
|
PhabricatorPhurlURLTransaction::MAILTAG_DETAILS =>
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_ALIAS:
|
pht(
|
||||||
$overdrawn = $this->validateIsTextFieldTooLong(
|
"A URL's details change."),
|
||||||
$object->getName(),
|
);
|
||||||
$xactions,
|
|
||||||
64);
|
|
||||||
|
|
||||||
if ($overdrawn) {
|
|
||||||
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Alias Too Long'),
|
|
||||||
pht('The alias can be no longer than 64 characters.'),
|
|
||||||
nonempty(last($xactions), null));
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($xactions as $xaction) {
|
|
||||||
if ($xaction->getOldValue() != $xaction->getNewValue()) {
|
|
||||||
$new_alias = $xaction->getNewValue();
|
|
||||||
$debug_alias = new PHUIInvisibleCharacterView($new_alias);
|
|
||||||
if (!preg_match('/[a-zA-Z]/', $new_alias)) {
|
|
||||||
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Invalid Alias'),
|
|
||||||
pht('The alias you provided (%s) must contain at least one '.
|
|
||||||
'letter.',
|
|
||||||
$debug_alias),
|
|
||||||
$xaction);
|
|
||||||
}
|
|
||||||
if (preg_match('/[^a-z0-9]/i', $new_alias)) {
|
|
||||||
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Invalid Alias'),
|
|
||||||
pht('The alias you provided (%s) may only contain letters and '.
|
|
||||||
'numbers.',
|
|
||||||
$debug_alias),
|
|
||||||
$xaction);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
case PhabricatorPhurlURLTransaction::TYPE_URL:
|
|
||||||
$missing = $this->validateIsEmptyTextField(
|
|
||||||
$object->getLongURL(),
|
|
||||||
$xactions);
|
|
||||||
|
|
||||||
if ($missing) {
|
|
||||||
$error = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Required'),
|
|
||||||
pht('URL path is required.'),
|
|
||||||
nonempty(last($xactions), null));
|
|
||||||
|
|
||||||
$error->setIsMissingFieldError(true);
|
|
||||||
$errors[] = $error;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($xactions as $xaction) {
|
|
||||||
if ($xaction->getOldValue() != $xaction->getNewValue()) {
|
|
||||||
$protocols = PhabricatorEnv::getEnvConfig('uri.allowed-protocols');
|
|
||||||
$uri = new PhutilURI($xaction->getNewValue());
|
|
||||||
if (!isset($protocols[$uri->getProtocol()])) {
|
|
||||||
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
|
||||||
$type,
|
|
||||||
pht('Invalid URL'),
|
|
||||||
pht('The protocol of the URL is invalid.'),
|
|
||||||
null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $errors;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function shouldPublishFeedStory(
|
protected function shouldPublishFeedStory(
|
||||||
|
@ -188,36 +52,17 @@ final class PhabricatorPhurlURLEditor
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function supportsSearch() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function shouldSendMail(
|
|
||||||
PhabricatorLiskDAO $object,
|
|
||||||
array $xactions) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getMailSubjectPrefix() {
|
protected function getMailSubjectPrefix() {
|
||||||
return pht('[Phurl]');
|
return pht('[Phurl]');
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getMailTo(PhabricatorLiskDAO $object) {
|
protected function getMailTo(PhabricatorLiskDAO $object) {
|
||||||
$phids = array();
|
$phids = array();
|
||||||
|
|
||||||
$phids[] = $this->getActingAsPHID();
|
$phids[] = $this->getActingAsPHID();
|
||||||
|
|
||||||
return $phids;
|
return $phids;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getMailTagsMap() {
|
|
||||||
return array(
|
|
||||||
PhabricatorPhurlURLTransaction::MAILTAG_DETAILS =>
|
|
||||||
pht(
|
|
||||||
"A URL's details change."),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function buildMailTemplate(PhabricatorLiskDAO $object) {
|
protected function buildMailTemplate(PhabricatorLiskDAO $object) {
|
||||||
$id = $object->getID();
|
$id = $object->getID();
|
||||||
$name = $object->getName();
|
$name = $object->getName();
|
||||||
|
@ -255,7 +100,7 @@ final class PhabricatorPhurlURLEditor
|
||||||
|
|
||||||
$errors = array();
|
$errors = array();
|
||||||
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
$errors[] = new PhabricatorApplicationTransactionValidationError(
|
||||||
PhabricatorPhurlURLTransaction::TYPE_ALIAS,
|
PhabricatorPhurlURLAliasTransaction::TRANSACTIONTYPE,
|
||||||
pht('Duplicate'),
|
pht('Duplicate'),
|
||||||
pht('This alias is already in use.'),
|
pht('This alias is already in use.'),
|
||||||
null);
|
null);
|
||||||
|
|
|
@ -4,7 +4,7 @@ final class PhabricatorPhurlURLSearchEngine
|
||||||
extends PhabricatorApplicationSearchEngine {
|
extends PhabricatorApplicationSearchEngine {
|
||||||
|
|
||||||
public function getResultTypeDescription() {
|
public function getResultTypeDescription() {
|
||||||
return pht('Shortened URLs');
|
return pht('Phurl URLs');
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
|
|
|
@ -1,12 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
final class PhabricatorPhurlURLTransaction
|
final class PhabricatorPhurlURLTransaction
|
||||||
extends PhabricatorApplicationTransaction {
|
extends PhabricatorModularTransaction {
|
||||||
|
|
||||||
const TYPE_NAME = 'phurl.name';
|
|
||||||
const TYPE_URL = 'phurl.longurl';
|
|
||||||
const TYPE_ALIAS = 'phurl.alias';
|
|
||||||
const TYPE_DESCRIPTION = 'phurl.description';
|
|
||||||
|
|
||||||
const MAILTAG_DETAILS = 'phurl-details';
|
const MAILTAG_DETAILS = 'phurl-details';
|
||||||
|
|
||||||
|
@ -22,14 +17,18 @@ final class PhabricatorPhurlURLTransaction
|
||||||
return new PhabricatorPhurlURLTransactionComment();
|
return new PhabricatorPhurlURLTransactionComment();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getBaseTransactionClass() {
|
||||||
|
return 'PhabricatorPhurlURLTransactionType';
|
||||||
|
}
|
||||||
|
|
||||||
public function getRequiredHandlePHIDs() {
|
public function getRequiredHandlePHIDs() {
|
||||||
$phids = parent::getRequiredHandlePHIDs();
|
$phids = parent::getRequiredHandlePHIDs();
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
switch ($this->getTransactionType()) {
|
||||||
case self::TYPE_NAME:
|
case PhabricatorPhurlURLNameTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_URL:
|
case PhabricatorPhurlURLLongURLTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_ALIAS:
|
case PhabricatorPhurlURLAliasTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_DESCRIPTION:
|
case PhabricatorPhurlURLDescriptionTransaction::TRANSACTIONTYPE:
|
||||||
$phids[] = $this->getObjectPHID();
|
$phids[] = $this->getObjectPHID();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -37,203 +36,13 @@ final class PhabricatorPhurlURLTransaction
|
||||||
return $phids;
|
return $phids;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function shouldHide() {
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return ($old === null);
|
|
||||||
}
|
|
||||||
return parent::shouldHide();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getIcon() {
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
case self::TYPE_URL:
|
|
||||||
case self::TYPE_ALIAS:
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return 'fa-pencil';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return parent::getIcon();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitle() {
|
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
$object_phid = $this->getObjectPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created this URL.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the name of the URL from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_URL:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the destination of the URL to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$new);
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the destination of the URL from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_ALIAS:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the alias of the URL to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$new);
|
|
||||||
} else if ($new === null) {
|
|
||||||
return pht(
|
|
||||||
'%s removed the alias of the URL.',
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the alias of the URL from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return pht(
|
|
||||||
"%s updated the URL's description.",
|
|
||||||
$this->renderHandleLink($author_phid));
|
|
||||||
}
|
|
||||||
return parent::getTitle();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getTitleForFeed() {
|
|
||||||
$author_phid = $this->getAuthorPHID();
|
|
||||||
$object_phid = $this->getObjectPHID();
|
|
||||||
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
$viewer = $this->getViewer();
|
|
||||||
|
|
||||||
$type = $this->getTransactionType();
|
|
||||||
switch ($type) {
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s created %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the name of %s from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_URL:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the destination of %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
$new);
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the destination of %s from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_ALIAS:
|
|
||||||
if ($old === null) {
|
|
||||||
return pht(
|
|
||||||
'%s set the alias of %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
$new);
|
|
||||||
} else if ($new === null) {
|
|
||||||
return pht(
|
|
||||||
'%s removed the alias of %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
} else {
|
|
||||||
return pht(
|
|
||||||
'%s changed the alias of %s from %s to %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid),
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return pht(
|
|
||||||
'%s updated the description of %s.',
|
|
||||||
$this->renderHandleLink($author_phid),
|
|
||||||
$this->renderHandleLink($object_phid));
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getTitleForFeed();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getColor() {
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_NAME:
|
|
||||||
case self::TYPE_URL:
|
|
||||||
case self::TYPE_ALIAS:
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return PhabricatorTransactions::COLOR_GREEN;
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::getColor();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function hasChangeDetails() {
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
return ($this->getOldValue() !== null);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::hasChangeDetails();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function renderChangeDetails(PhabricatorUser $viewer) {
|
|
||||||
switch ($this->getTransactionType()) {
|
|
||||||
case self::TYPE_DESCRIPTION:
|
|
||||||
$old = $this->getOldValue();
|
|
||||||
$new = $this->getNewValue();
|
|
||||||
|
|
||||||
return $this->renderTextCorpusChangeDetails(
|
|
||||||
$viewer,
|
|
||||||
$old,
|
|
||||||
$new);
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent::renderChangeDetails($viewer);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getMailTags() {
|
public function getMailTags() {
|
||||||
$tags = array();
|
$tags = array();
|
||||||
switch ($this->getTransactionType()) {
|
switch ($this->getTransactionType()) {
|
||||||
case self::TYPE_NAME:
|
case PhabricatorPhurlURLNameTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_DESCRIPTION:
|
case PhabricatorPhurlURLLongURLTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_URL:
|
case PhabricatorPhurlURLAliasTransaction::TRANSACTIONTYPE:
|
||||||
case self::TYPE_ALIAS:
|
case PhabricatorPhurlURLDescriptionTransaction::TRANSACTIONTYPE:
|
||||||
$tags[] = self::MAILTAG_DETAILS;
|
$tags[] = self::MAILTAG_DETAILS;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,77 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPhurlURLAliasTransaction
|
||||||
|
extends PhabricatorPhurlURLTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'phurl.alias';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getAlias();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setAlias($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the alias from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the alias of %s from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getAlias(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Phurls must have an alias.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
$max_length = $object->getColumnMaximumByteLength('alias');
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
$new_alias = $xaction->getNewValue();
|
||||||
|
|
||||||
|
// Check length
|
||||||
|
$new_length = strlen($new_alias);
|
||||||
|
if ($new_length > $max_length) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The alias can be no longer than %d characters.', $max_length));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check characters
|
||||||
|
if ($xaction->getOldValue() != $xaction->getNewValue()) {
|
||||||
|
$debug_alias = new PHUIInvisibleCharacterView($new_alias);
|
||||||
|
if (!preg_match('/[a-zA-Z]/', $new_alias)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The alias you provided (%s) must contain at least one '.
|
||||||
|
'letter.',
|
||||||
|
$debug_alias));
|
||||||
|
}
|
||||||
|
if (preg_match('/[^a-z0-9]/i', $new_alias)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The alias you provided (%s) may only contain letters and '.
|
||||||
|
'numbers.',
|
||||||
|
$debug_alias));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-compress';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPhurlURLDescriptionTransaction
|
||||||
|
extends PhabricatorPhurlURLTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'phurl.description';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setDescription($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the description.',
|
||||||
|
$this->renderAuthor());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s updated the description for %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function hasChangeDetailView() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getMailDiffSectionHeader() {
|
||||||
|
return pht('CHANGES TO PHURL DESCRIPTION');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newChangeDetailView() {
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
|
||||||
|
return id(new PhabricatorApplicationTransactionTextDiffDetailView())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->setOldText($this->getOldValue())
|
||||||
|
->setNewText($this->getNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function newRemarkupChanges() {
|
||||||
|
$changes = array();
|
||||||
|
|
||||||
|
$changes[] = $this->newRemarkupChange()
|
||||||
|
->setOldValue($this->getOldValue())
|
||||||
|
->setNewValue($this->getNewValue());
|
||||||
|
|
||||||
|
return $changes;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-file-text-o';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,59 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPhurlURLLongURLTransaction
|
||||||
|
extends PhabricatorPhurlURLTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'phurl.longurl';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getLongURL();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setLongURL($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the destination URL from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the destination URL %s from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getLongURL(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('URL path is required'));
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($xactions as $xaction) {
|
||||||
|
if ($xaction->getOldValue() != $xaction->getNewValue()) {
|
||||||
|
$protocols = PhabricatorEnv::getEnvConfig('uri.allowed-protocols');
|
||||||
|
$uri = new PhutilURI($xaction->getNewValue());
|
||||||
|
if (!isset($protocols[$uri->getProtocol()])) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('The protocol of the URL is invalid.'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getIcon() {
|
||||||
|
return 'fa-external-link-square';
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
final class PhabricatorPhurlURLNameTransaction
|
||||||
|
extends PhabricatorPhurlURLTransactionType {
|
||||||
|
|
||||||
|
const TRANSACTIONTYPE = 'phurl.name';
|
||||||
|
|
||||||
|
public function generateOldValue($object) {
|
||||||
|
return $object->getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function applyInternalEffects($object, $value) {
|
||||||
|
$object->setName($value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitle() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the name of the URL from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getTitleForFeed() {
|
||||||
|
return pht(
|
||||||
|
'%s changed the name of %s from %s to %s.',
|
||||||
|
$this->renderAuthor(),
|
||||||
|
$this->renderObject(),
|
||||||
|
$this->renderOldValue(),
|
||||||
|
$this->renderNewValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function validateTransactions($object, array $xactions) {
|
||||||
|
$errors = array();
|
||||||
|
|
||||||
|
if ($this->isEmptyTextTransaction($object->getName(), $xactions)) {
|
||||||
|
$errors[] = $this->newRequiredError(
|
||||||
|
pht('Phurls must have a name.'));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $errors;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,4 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
abstract class PhabricatorPhurlURLTransactionType
|
||||||
|
extends PhabricatorModularTransactionType {}
|
|
@ -11,6 +11,10 @@ final class PhabricatorProjectColumnSearchEngine
|
||||||
return 'PhabricatorProjectApplication';
|
return 'PhabricatorProjectApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function newQuery() {
|
public function newQuery() {
|
||||||
return new PhabricatorProjectColumnQuery();
|
return new PhabricatorProjectColumnQuery();
|
||||||
}
|
}
|
||||||
|
@ -25,7 +29,6 @@ final class PhabricatorProjectColumnSearchEngine
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
|
|
||||||
|
|
|
@ -9,6 +9,10 @@ final class ReleephBranchSearchEngine
|
||||||
return pht('Releeph Branches');
|
return pht('Releeph Branches');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function getApplicationClassName() {
|
public function getApplicationClassName() {
|
||||||
return 'PhabricatorReleephApplication';
|
return 'PhabricatorReleephApplication';
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class ReleephProductSearchEngine
|
||||||
return 'PhabricatorReleephApplication';
|
return 'PhabricatorReleephApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
$saved = new PhabricatorSavedQuery();
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,10 @@ final class ReleephRequestSearchEngine
|
||||||
return 'PhabricatorReleephApplication';
|
return 'PhabricatorReleephApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function setBranch(ReleephBranch $branch) {
|
public function setBranch(ReleephBranch $branch) {
|
||||||
$this->branch = $branch;
|
$this->branch = $branch;
|
||||||
return $this;
|
return $this;
|
||||||
|
|
|
@ -14,7 +14,7 @@ final class PhabricatorRepositoryDiscoveryEngine
|
||||||
private $commitCache = array();
|
private $commitCache = array();
|
||||||
private $workingSet = array();
|
private $workingSet = array();
|
||||||
|
|
||||||
const MAX_COMMIT_CACHE_SIZE = 2048;
|
const MAX_COMMIT_CACHE_SIZE = 65535;
|
||||||
|
|
||||||
|
|
||||||
/* -( Discovering Repositories )------------------------------------------- */
|
/* -( Discovering Repositories )------------------------------------------- */
|
||||||
|
@ -233,7 +233,7 @@ final class PhabricatorRepositoryDiscoveryEngine
|
||||||
$limit,
|
$limit,
|
||||||
$repository->getSubversionBaseURI($at_rev));
|
$repository->getSubversionBaseURI($at_rev));
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
$stderr = $ex->getStdErr();
|
$stderr = $ex->getStderr();
|
||||||
if (preg_match('/(path|File) not found/', $stderr)) {
|
if (preg_match('/(path|File) not found/', $stderr)) {
|
||||||
// We've gone all the way back through history and this path was not
|
// We've gone all the way back through history and this path was not
|
||||||
// affected by earlier commits.
|
// affected by earlier commits.
|
||||||
|
@ -476,6 +476,15 @@ final class PhabricatorRepositoryDiscoveryEngine
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$max_size = self::MAX_COMMIT_CACHE_SIZE;
|
||||||
|
|
||||||
|
// If we're filling more identifiers than would fit in the cache, ignore
|
||||||
|
// the ones that don't fit. Because the cache is FIFO, overfilling it can
|
||||||
|
// cause the entire cache to miss. See T12296.
|
||||||
|
if (count($identifiers) > $max_size) {
|
||||||
|
$identifiers = array_slice($identifiers, 0, $max_size);
|
||||||
|
}
|
||||||
|
|
||||||
// When filling the cache we ignore commits which have been marked as
|
// When filling the cache we ignore commits which have been marked as
|
||||||
// unreachable, treating them as though they do not exist. When recording
|
// unreachable, treating them as though they do not exist. When recording
|
||||||
// commits later we'll revive commits that exist but are unreachable.
|
// commits later we'll revive commits that exist but are unreachable.
|
||||||
|
@ -492,7 +501,7 @@ final class PhabricatorRepositoryDiscoveryEngine
|
||||||
$this->commitCache[$commit->getCommitIdentifier()] = true;
|
$this->commitCache[$commit->getCommitIdentifier()] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (count($this->commitCache) > self::MAX_COMMIT_CACHE_SIZE) {
|
while (count($this->commitCache) > $max_size) {
|
||||||
array_shift($this->commitCache);
|
array_shift($this->commitCache);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,7 +108,7 @@ final class PhabricatorRepositoryMirrorEngine
|
||||||
->setCWD($repository->getLocalPath())
|
->setCWD($repository->getLocalPath())
|
||||||
->resolvex();
|
->resolvex();
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
if (preg_match('/no changes found/', $ex->getStdOut())) {
|
if (preg_match('/no changes found/', $ex->getStdout())) {
|
||||||
// mercurial says nothing changed, but that's good
|
// mercurial says nothing changed, but that's good
|
||||||
} else {
|
} else {
|
||||||
throw $ex;
|
throw $ex;
|
||||||
|
|
|
@ -471,7 +471,7 @@ final class PhabricatorRepositoryPullEngine
|
||||||
$future->resolvex();
|
$future->resolvex();
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
$err = $ex->getError();
|
$err = $ex->getError();
|
||||||
$stdout = $ex->getStdOut();
|
$stdout = $ex->getStdout();
|
||||||
|
|
||||||
// NOTE: Between versions 2.1 and 2.1.1, Mercurial changed the behavior
|
// NOTE: Between versions 2.1 and 2.1.1, Mercurial changed the behavior
|
||||||
// of "hg pull" to return 1 in case of a successful pull with no changes.
|
// of "hg pull" to return 1 in case of a successful pull with no changes.
|
||||||
|
|
|
@ -11,6 +11,10 @@ final class PhabricatorSearchApplicationSearchEngine
|
||||||
return 'PhabricatorSearchApplication';
|
return 'PhabricatorSearchApplication';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
public function buildSavedQueryFromRequest(AphrontRequest $request) {
|
||||||
$saved = new PhabricatorSavedQuery();
|
$saved = new PhabricatorSavedQuery();
|
||||||
|
|
||||||
|
|
|
@ -88,15 +88,25 @@ final class PhabricatorDesktopNotificationsSettingsPanel
|
||||||
'for this Phabricator instance. Consult your browser settings / '.
|
'for this Phabricator instance. Consult your browser settings / '.
|
||||||
'documentation to figure out how to clear this setting, do so, '.
|
'documentation to figure out how to clear this setting, do so, '.
|
||||||
'and then re-visit this page to grant permission.'));
|
'and then re-visit this page to grant permission.'));
|
||||||
|
|
||||||
|
$message_id = celerity_generate_unique_node_id();
|
||||||
|
|
||||||
|
$message_container = phutil_tag(
|
||||||
|
'span',
|
||||||
|
array(
|
||||||
|
'id' => $message_id,
|
||||||
|
));
|
||||||
|
|
||||||
$status_box = id(new PHUIInfoView())
|
$status_box = id(new PHUIInfoView())
|
||||||
->setSeverity(PHUIInfoView::SEVERITY_NOTICE)
|
->setSeverity(PHUIInfoView::SEVERITY_NOTICE)
|
||||||
->setID($status_id)
|
->setID($status_id)
|
||||||
->setIsHidden(true)
|
->setIsHidden(true)
|
||||||
->appendChild($accept_ask);
|
->appendChild($message_container);
|
||||||
|
|
||||||
$control_config = array(
|
$control_config = array(
|
||||||
'controlID' => $control_id,
|
'controlID' => $control_id,
|
||||||
'statusID' => $status_id,
|
'statusID' => $status_id,
|
||||||
|
'messageID' => $message_id,
|
||||||
'browserStatusID' => $browser_status_id,
|
'browserStatusID' => $browser_status_id,
|
||||||
'defaultMode' => 0,
|
'defaultMode' => 0,
|
||||||
'desktopMode' => 1,
|
'desktopMode' => 1,
|
||||||
|
|
|
@ -2126,6 +2126,13 @@ abstract class PhabricatorEditEngine
|
||||||
|
|
||||||
$configs = msort($configs, 'getCreateSortKey');
|
$configs = msort($configs, 'getCreateSortKey');
|
||||||
|
|
||||||
|
// Attach this specific engine to configurations we load so they can access
|
||||||
|
// any runtime configuration. For example, this allows us to generate the
|
||||||
|
// correct "Create Form" buttons when editing forms, see T12301.
|
||||||
|
foreach ($configs as $config) {
|
||||||
|
$config->attachEngine($this);
|
||||||
|
}
|
||||||
|
|
||||||
return $configs;
|
return $configs;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1462,6 +1462,12 @@ abstract class PhabricatorApplicationTransactionEditor
|
||||||
|
|
||||||
$type = $u->getTransactionType();
|
$type = $u->getTransactionType();
|
||||||
|
|
||||||
|
$xtype = $this->getModularTransactionType($type);
|
||||||
|
if ($xtype) {
|
||||||
|
$object = $this->object;
|
||||||
|
return $xtype->mergeTransactions($object, $u, $v);
|
||||||
|
}
|
||||||
|
|
||||||
switch ($type) {
|
switch ($type) {
|
||||||
case PhabricatorTransactions::TYPE_SUBSCRIBERS:
|
case PhabricatorTransactions::TYPE_SUBSCRIBERS:
|
||||||
return $this->mergePHIDOrEdgeTransactions($u, $v);
|
return $this->mergePHIDOrEdgeTransactions($u, $v);
|
||||||
|
@ -2318,51 +2324,6 @@ abstract class PhabricatorApplicationTransactionEditor
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Check that text field input isn't longer than a specified length.
|
|
||||||
*
|
|
||||||
* A text field input is invalid if the length of the input is longer than a
|
|
||||||
* specified length. This length can be determined by the space allotted in
|
|
||||||
* the database, or given arbitrarily.
|
|
||||||
* This method is intended to make implementing @{method:validateTransaction}
|
|
||||||
* more convenient:
|
|
||||||
*
|
|
||||||
* $overdrawn = $this->validateIsTextFieldTooLong(
|
|
||||||
* $object->getName(),
|
|
||||||
* $xactions,
|
|
||||||
* $field_length);
|
|
||||||
*
|
|
||||||
* This will return `true` if the net effect of the object and transactions
|
|
||||||
* is a field that is too long.
|
|
||||||
*
|
|
||||||
* @param wild Current field value.
|
|
||||||
* @param list<PhabricatorApplicationTransaction> Transactions editing the
|
|
||||||
* field.
|
|
||||||
* @param integer for maximum field length.
|
|
||||||
* @return bool True if the field will be too long after edits.
|
|
||||||
*/
|
|
||||||
protected function validateIsTextFieldTooLong(
|
|
||||||
$field_value,
|
|
||||||
array $xactions,
|
|
||||||
$length) {
|
|
||||||
|
|
||||||
if ($xactions) {
|
|
||||||
$new_value_length = phutil_utf8_strlen(last($xactions)->getNewValue());
|
|
||||||
if ($new_value_length <= $length) {
|
|
||||||
return false;
|
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$old_value_length = phutil_utf8_strlen($field_value);
|
|
||||||
if ($old_value_length <= $length) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* -( Implicit CCs )------------------------------------------------------- */
|
/* -( Implicit CCs )------------------------------------------------------- */
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,10 @@ final class PhabricatorEditEngineSearchEngine
|
||||||
return id(new PhabricatorEditEngineQuery());
|
return id(new PhabricatorEditEngineQuery());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function canUseInPanelContext() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected function buildQueryFromParameters(array $map) {
|
protected function buildQueryFromParameters(array $map) {
|
||||||
$query = $this->newQuery();
|
$query = $this->newQuery();
|
||||||
return $query;
|
return $query;
|
||||||
|
|
|
@ -87,6 +87,13 @@ abstract class PhabricatorModularTransactionType
|
||||||
return array();
|
return array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function mergeTransactions(
|
||||||
|
$object,
|
||||||
|
PhabricatorApplicationTransaction $u,
|
||||||
|
PhabricatorApplicationTransaction $v) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
final public function setStorage(
|
final public function setStorage(
|
||||||
PhabricatorApplicationTransaction $xaction) {
|
PhabricatorApplicationTransaction $xaction) {
|
||||||
$this->storage = $xaction;
|
$this->storage = $xaction;
|
||||||
|
|
|
@ -19,17 +19,21 @@ final class PhabricatorApplicationTransactionTextDiffDetailView
|
||||||
public function renderForMail() {
|
public function renderForMail() {
|
||||||
$diff = $this->buildDiff();
|
$diff = $this->buildDiff();
|
||||||
|
|
||||||
|
$viewer = $this->getViewer();
|
||||||
|
$old_bright = $viewer->getCSSValue('old-bright');
|
||||||
|
$new_bright = $viewer->getCSSValue('new-bright');
|
||||||
|
|
||||||
$old_styles = array(
|
$old_styles = array(
|
||||||
'padding: 0 2px;',
|
'padding: 0 2px;',
|
||||||
'color: #333333;',
|
'color: #333333;',
|
||||||
'background: #f8cbcb;',
|
"background: {$old_bright};",
|
||||||
);
|
);
|
||||||
$old_styles = implode(' ', $old_styles);
|
$old_styles = implode(' ', $old_styles);
|
||||||
|
|
||||||
$new_styles = array(
|
$new_styles = array(
|
||||||
'padding: 0 2px;',
|
'padding: 0 2px;',
|
||||||
'color: #333333;',
|
'color: #333333;',
|
||||||
'background: #a6f3a6;',
|
"background: {$new_bright};",
|
||||||
);
|
);
|
||||||
$new_styles = implode(' ', $new_styles);
|
$new_styles = implode(' ', $new_styles);
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,7 @@ final class PhabricatorXHProfApplication extends PhabricatorApplication {
|
||||||
'' => 'PhabricatorXHProfSampleListController',
|
'' => 'PhabricatorXHProfSampleListController',
|
||||||
'list/(?P<view>[^/]+)/' => 'PhabricatorXHProfSampleListController',
|
'list/(?P<view>[^/]+)/' => 'PhabricatorXHProfSampleListController',
|
||||||
'profile/(?P<phid>[^/]+)/' => 'PhabricatorXHProfProfileController',
|
'profile/(?P<phid>[^/]+)/' => 'PhabricatorXHProfProfileController',
|
||||||
|
'import/drop/' => 'PhabricatorXHProfDropController',
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue