Correct Aphlict websocket URI construction after PHP8 compatibility changes
[phabricator.git] / src / applications / diffusion / controller / DiffusionRepositoryTestAutomationController.php
blobbc1c470caab20cf5f5785db1211c823f9a0ef4a6
1 <?php
3 final class DiffusionRepositoryTestAutomationController
4 extends DiffusionRepositoryManageController {
6 public function handleRequest(AphrontRequest $request) {
7 $response = $this->loadDiffusionContextForEdit();
8 if ($response) {
9 return $response;
12 $viewer = $this->getViewer();
13 $drequest = $this->getDiffusionRequest();
14 $repository = $drequest->getRepository();
16 $panel_uri = id(new DiffusionRepositoryAutomationManagementPanel())
17 ->setRepository($repository)
18 ->getPanelURI();
20 if (!$repository->canPerformAutomation()) {
21 return $this->newDialog()
22 ->setTitle(pht('Automation Not Configured'))
23 ->appendParagraph(
24 pht(
25 'You can not run a configuration test for this repository '.
26 'because you have not configured repository automation yet. '.
27 'Configure it first, then test the configuration.'))
28 ->addCancelButton($panel_uri);
31 if ($request->isFormPost()) {
32 $op = new DrydockTestRepositoryOperation();
34 $operation = DrydockRepositoryOperation::initializeNewOperation($op)
35 ->setAuthorPHID($viewer->getPHID())
36 ->setObjectPHID($repository->getPHID())
37 ->setRepositoryPHID($repository->getPHID())
38 ->setRepositoryTarget('none:')
39 ->save();
41 $operation->scheduleUpdate();
43 $operation_id = $operation->getID();
44 $operation_uri = "/drydock/operation/{$operation_id}/";
46 return id(new AphrontRedirectResponse())
47 ->setURI($operation_uri);
50 return $this->newDialog()
51 ->setTitle(pht('Test Automation Configuration'))
52 ->appendParagraph(
53 pht(
54 'This configuration test will build a working copy of the '.
55 'repository and perform some basic validation. If it works, '.
56 'your configuration is substantially correct.'))
57 ->appendParagraph(
58 pht(
59 'The test will not perform any writes against the repository, so '.
60 'write operations may still fail even if the test passes. This '.
61 'test covers building and reading working copies, but not writing '.
62 'to them.'))
63 ->appendParagraph(
64 pht(
65 'If you run into write failures despite passing this test, '.
66 'it suggests that your setup is nearly correct but authentication '.
67 'is probably not fully configured.'))
68 ->addCancelButton($panel_uri)
69 ->addSubmitButton(pht('Start Test'));