當前位置: 首頁>>代碼示例>>PHP>>正文


PHP PhabricatorPolicyFilter::requireCapability方法代碼示例

本文整理匯總了PHP中PhabricatorPolicyFilter::requireCapability方法的典型用法代碼示例。如果您正苦於以下問題:PHP PhabricatorPolicyFilter::requireCapability方法的具體用法?PHP PhabricatorPolicyFilter::requireCapability怎麽用?PHP PhabricatorPolicyFilter::requireCapability使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PhabricatorPolicyFilter的用法示例。


在下文中一共展示了PhabricatorPolicyFilter::requireCapability方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: initializeNewSSHKey

 public static function initializeNewSSHKey(PhabricatorUser $viewer, PhabricatorSSHPublicKeyInterface $object)
 {
     // You must be able to edit an object to create a new key on it.
     PhabricatorPolicyFilter::requireCapability($viewer, $object, PhabricatorPolicyCapability::CAN_EDIT);
     $object_phid = $object->getPHID();
     return id(new self())->setIsActive(1)->setObjectPHID($object_phid)->attachObject($object);
 }
開發者ID:rchicoli,項目名稱:phabricator,代碼行數:7,代碼來源:PhabricatorAuthSSHKey.php

示例2: handleRequest

 public function handleRequest(AphrontRequest $request)
 {
     $viewer = $this->getViewer();
     // Redirect "/panel/XYZ/" to the viewer's personal settings panel. This
     // was the primary URI before global settings were introduced and allows
     // generation of viewer-agnostic URIs for email.
     $panel = $request->getURIData('panel');
     if ($panel) {
         $panel = phutil_escape_uri($panel);
         $username = $viewer->getUsername();
         $panel_uri = "/user/{$username}/page/{$panel}/";
         $panel_uri = $this->getApplicationURI($panel_uri);
         return id(new AphrontRedirectResponse())->setURI($panel_uri);
     }
     $username = $request->getURIData('username');
     $builtin = $request->getURIData('builtin');
     $key = $request->getURIData('pageKey');
     if ($builtin) {
         $this->builtinKey = $builtin;
         $preferences = id(new PhabricatorUserPreferencesQuery())->setViewer($viewer)->withBuiltinKeys(array($builtin))->requireCapabilities(array(PhabricatorPolicyCapability::CAN_VIEW, PhabricatorPolicyCapability::CAN_EDIT))->executeOne();
         if (!$preferences) {
             $preferences = id(new PhabricatorUserPreferences())->attachUser(null)->setBuiltinKey($builtin);
         }
     } else {
         $user = id(new PhabricatorPeopleQuery())->setViewer($viewer)->withUsernames(array($username))->requireCapabilities(array(PhabricatorPolicyCapability::CAN_VIEW, PhabricatorPolicyCapability::CAN_EDIT))->executeOne();
         if (!$user) {
             return new Aphront404Response();
         }
         $preferences = PhabricatorUserPreferences::loadUserPreferences($user);
         $this->user = $user;
     }
     if (!$preferences) {
         return new Aphront404Response();
     }
     PhabricatorPolicyFilter::requireCapability($viewer, $preferences, PhabricatorPolicyCapability::CAN_EDIT);
     $this->preferences = $preferences;
     $panels = $this->buildPanels($preferences);
     $nav = $this->renderSideNav($panels);
     $key = $nav->selectFilter($key, head($panels)->getPanelKey());
     $panel = $panels[$key]->setController($this)->setNavigation($nav);
     $response = $panel->processRequest($request);
     if ($response instanceof AphrontResponse || $response instanceof AphrontResponseProducerInterface) {
         return $response;
     }
     $crumbs = $this->buildApplicationCrumbs();
     $crumbs->addTextCrumb($panel->getPanelName());
     $title = $panel->getPanelName();
     $view = id(new PHUITwoColumnView())->setNavigation($nav)->setMainColumn($response);
     return $this->newPage()->setTitle($title)->setCrumbs($crumbs)->appendChild($view);
 }
開發者ID:rchicoli,項目名稱:phabricator,代碼行數:50,代碼來源:PhabricatorSettingsMainController.php

示例3: execute

 protected function execute(ConduitAPIRequest $request)
 {
     $application = id(new PhabricatorApplicationQuery())->setViewer($request->getUser())->withClasses(array('PhabricatorDiffusionApplication'))->executeOne();
     PhabricatorPolicyFilter::requireCapability($request->getUser(), $application, DiffusionCreateRepositoriesCapability::CAPABILITY);
     // TODO: This has some duplication with (and lacks some of the validation
     // of) the web workflow; refactor things so they can share more code as this
     // stabilizes. Specifically, this should move to transactions since they
     // work properly now.
     $repository = PhabricatorRepository::initializeNewRepository($request->getUser());
     $repository->setName($request->getValue('name'));
     $callsign = $request->getValue('callsign');
     if (!preg_match('/^[A-Z]+\\z/', $callsign)) {
         throw new ConduitException('ERR-BAD-CALLSIGN');
     }
     $repository->setCallsign($callsign);
     $local_path = PhabricatorEnv::getEnvConfig('repository.default-local-path');
     $local_path = rtrim($local_path, '/');
     $local_path = $local_path . '/' . $callsign . '/';
     $vcs = $request->getValue('vcs');
     $map = array('git' => PhabricatorRepositoryType::REPOSITORY_TYPE_GIT, 'hg' => PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL, 'svn' => PhabricatorRepositoryType::REPOSITORY_TYPE_SVN);
     if (empty($map[$vcs])) {
         throw new ConduitException('ERR-UNKNOWN-REPOSITORY-VCS');
     }
     $repository->setVersionControlSystem($map[$vcs]);
     $repository->setCredentialPHID($request->getValue('credentialPHID'));
     $remote_uri = $request->getValue('uri');
     PhabricatorRepository::assertValidRemoteURI($remote_uri);
     $details = array('encoding' => $request->getValue('encoding'), 'description' => $request->getValue('description'), 'tracking-enabled' => (bool) $request->getValue('tracking', true), 'remote-uri' => $remote_uri, 'local-path' => $local_path, 'branch-filter' => array_fill_keys($request->getValue('branchFilter', array()), true), 'close-commits-filter' => array_fill_keys($request->getValue('closeCommitsFilter', array()), true), 'pull-frequency' => $request->getValue('pullFrequency'), 'default-branch' => $request->getValue('defaultBranch'), 'herald-disabled' => !$request->getValue('heraldEnabled', true), 'svn-subpath' => $request->getValue('svnSubpath'), 'disable-autoclose' => !$request->getValue('autocloseEnabled', true));
     foreach ($details as $key => $value) {
         $repository->setDetail($key, $value);
     }
     try {
         $repository->save();
     } catch (AphrontDuplicateKeyQueryException $ex) {
         throw new ConduitException('ERR-DUPLICATE');
     }
     return $repository->toDictionary();
 }
開發者ID:pugong,項目名稱:phabricator,代碼行數:38,代碼來源:RepositoryCreateConduitAPIMethod.php

示例4: requireCapabilities

 protected function requireCapabilities(PhabricatorLiskDAO $object, PhabricatorApplicationTransaction $xaction)
 {
     parent::requireCapabilities($object, $xaction);
     switch ($xaction->getTransactionType()) {
         case ConpherenceTransaction::TYPE_PARTICIPANTS:
             $old_map = array_fuse($xaction->getOldValue());
             $new_map = array_fuse($xaction->getNewValue());
             $add = array_keys(array_diff_key($new_map, $old_map));
             $rem = array_keys(array_diff_key($old_map, $new_map));
             $actor_phid = $this->requireActor()->getPHID();
             $is_join = $add === array($actor_phid) && !$rem;
             $is_leave = $rem === array($actor_phid) && !$add;
             if ($is_join) {
                 // You need CAN_JOIN to join a room.
                 PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_JOIN);
             } else {
                 if ($is_leave) {
                     // You don't need any capabilities to leave a conpherence thread.
                 } else {
                     // You need CAN_EDIT to change participants other than yourself.
                     PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
                 }
             }
             break;
             // This is similar to PhabricatorTransactions::TYPE_COMMENT so
             // use CAN_VIEW
         // This is similar to PhabricatorTransactions::TYPE_COMMENT so
         // use CAN_VIEW
         case ConpherenceTransaction::TYPE_FILES:
             PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_VIEW);
             break;
         case ConpherenceTransaction::TYPE_TITLE:
             PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
             break;
     }
 }
開發者ID:patelhardik,項目名稱:phabricator,代碼行數:36,代碼來源:ConpherenceEditor.php

示例5: processRequest

 public function processRequest()
 {
     $request = $this->getRequest();
     $viewer = $request->getUser();
     // NOTE: We can end up here via either "Create Repository", or via
     // "Import Repository", or via "Edit Remote", or via "Edit Policies". In
     // the latter two cases, we show only a few of the pages.
     $repository = null;
     switch ($this->edit) {
         case 'remote':
         case 'policy':
             $repository = $this->getDiffusionRequest()->getRepository();
             // Make sure we have CAN_EDIT.
             PhabricatorPolicyFilter::requireCapability($viewer, $repository, PhabricatorPolicyCapability::CAN_EDIT);
             $this->setRepository($repository);
             $cancel_uri = $this->getRepositoryControllerURI($repository, 'edit/');
             break;
         case 'import':
         case 'create':
             $this->requireApplicationCapability(DiffusionCreateRepositoriesCapability::CAPABILITY);
             $cancel_uri = $this->getApplicationURI('new/');
             break;
         default:
             throw new Exception('Invalid edit operation!');
     }
     $form = id(new PHUIPagedFormView())->setUser($viewer)->setCancelURI($cancel_uri);
     switch ($this->edit) {
         case 'remote':
             $title = pht('Edit Remote');
             $form->addPage('remote-uri', $this->buildRemoteURIPage())->addPage('auth', $this->buildAuthPage());
             break;
         case 'policy':
             $title = pht('Edit Policies');
             $form->addPage('policy', $this->buildPolicyPage());
             break;
         case 'create':
             $title = pht('Create Repository');
             $form->addPage('vcs', $this->buildVCSPage())->addPage('name', $this->buildNamePage())->addPage('policy', $this->buildPolicyPage())->addPage('done', $this->buildDonePage());
             break;
         case 'import':
             $title = pht('Import Repository');
             $form->addPage('vcs', $this->buildVCSPage())->addPage('name', $this->buildNamePage())->addPage('remote-uri', $this->buildRemoteURIPage())->addPage('auth', $this->buildAuthPage())->addPage('policy', $this->buildPolicyPage())->addPage('done', $this->buildDonePage());
             break;
     }
     if ($request->isFormPost()) {
         $form->readFromRequest($request);
         if ($form->isComplete()) {
             $is_create = $this->edit === 'import' || $this->edit === 'create';
             $is_auth = $this->edit == 'import' || $this->edit == 'remote';
             $is_policy = $this->edit != 'remote';
             $is_init = $this->edit == 'create';
             if ($is_create) {
                 $repository = PhabricatorRepository::initializeNewRepository($viewer);
             }
             $template = id(new PhabricatorRepositoryTransaction());
             $type_name = PhabricatorRepositoryTransaction::TYPE_NAME;
             $type_vcs = PhabricatorRepositoryTransaction::TYPE_VCS;
             $type_activate = PhabricatorRepositoryTransaction::TYPE_ACTIVATE;
             $type_local_path = PhabricatorRepositoryTransaction::TYPE_LOCAL_PATH;
             $type_remote_uri = PhabricatorRepositoryTransaction::TYPE_REMOTE_URI;
             $type_hosting = PhabricatorRepositoryTransaction::TYPE_HOSTING;
             $type_credential = PhabricatorRepositoryTransaction::TYPE_CREDENTIAL;
             $type_view = PhabricatorTransactions::TYPE_VIEW_POLICY;
             $type_edit = PhabricatorTransactions::TYPE_EDIT_POLICY;
             $type_push = PhabricatorRepositoryTransaction::TYPE_PUSH_POLICY;
             $xactions = array();
             // If we're creating a new repository, set all this core stuff.
             if ($is_create) {
                 $callsign = $form->getPage('name')->getControl('callsign')->getValue();
                 // We must set this to a unique value to save the repository
                 // initially, and it's immutable, so we don't bother using
                 // transactions to apply this change.
                 $repository->setCallsign($callsign);
                 // Put the repository in "Importing" mode until we finish
                 // parsing it.
                 $repository->setDetail('importing', true);
                 $xactions[] = id(clone $template)->setTransactionType($type_name)->setNewValue($form->getPage('name')->getControl('name')->getValue());
                 $xactions[] = id(clone $template)->setTransactionType($type_vcs)->setNewValue($form->getPage('vcs')->getControl('vcs')->getValue());
                 $activate = $form->getPage('done')->getControl('activate')->getValue();
                 $xactions[] = id(clone $template)->setTransactionType($type_activate)->setNewValue($activate == 'start');
                 $default_local_path = PhabricatorEnv::getEnvConfig('repository.default-local-path');
                 $default_local_path = rtrim($default_local_path, '/');
                 $default_local_path = $default_local_path . '/' . $callsign . '/';
                 $xactions[] = id(clone $template)->setTransactionType($type_local_path)->setNewValue($default_local_path);
             }
             if ($is_init) {
                 $xactions[] = id(clone $template)->setTransactionType($type_hosting)->setNewValue(true);
             }
             if ($is_auth) {
                 $xactions[] = id(clone $template)->setTransactionType($type_remote_uri)->setNewValue($form->getPage('remote-uri')->getControl('remoteURI')->getValue());
                 $xactions[] = id(clone $template)->setTransactionType($type_credential)->setNewValue($form->getPage('auth')->getControl('credential')->getValue());
             }
             if ($is_policy) {
                 $xactions[] = id(clone $template)->setTransactionType($type_view)->setNewValue($form->getPage('policy')->getControl('viewPolicy')->getValue());
                 $xactions[] = id(clone $template)->setTransactionType($type_edit)->setNewValue($form->getPage('policy')->getControl('editPolicy')->getValue());
                 if ($is_init || $repository->isHosted()) {
                     $xactions[] = id(clone $template)->setTransactionType($type_push)->setNewValue($form->getPage('policy')->getControl('pushPolicy')->getValue());
                 }
             }
             id(new PhabricatorRepositoryEditor())->setContinueOnNoEffect(true)->setContentSourceFromRequest($request)->setActor($viewer)->applyTransactions($repository, $xactions);
//.........這裏部分代碼省略.........
開發者ID:denghp,項目名稱:phabricator,代碼行數:101,代碼來源:DiffusionRepositoryCreateController.php

示例6: requireApplicationCapability

 protected function requireApplicationCapability($capability, PhabricatorUser $viewer)
 {
     $application = $this->getApplication();
     if (!$application) {
         return;
     }
     PhabricatorPolicyFilter::requireCapability($viewer, $this->getApplication(), $capability);
 }
開發者ID:NeoArmageddon,項目名稱:phabricator,代碼行數:8,代碼來源:ConduitAPIMethod.php

示例7: handleRequest

 public function handleRequest(AphrontRequest $request)
 {
     $viewer = $this->getViewer();
     $engine_key = $request->getURIData('engineKey');
     $this->setEngineKey($engine_key);
     $type = $request->getURIData('type');
     $is_create = $type == 'create';
     $engine = id(new PhabricatorEditEngineQuery())->setViewer($viewer)->withEngineKeys(array($engine_key))->requireCapabilities(array(PhabricatorPolicyCapability::CAN_VIEW, PhabricatorPolicyCapability::CAN_EDIT))->executeOne();
     if (!$engine) {
         return id(new Aphront404Response());
     }
     $cancel_uri = "/transactions/editengine/{$engine_key}/";
     $reorder_uri = "/transactions/editengine/{$engine_key}/sort/{$type}/";
     $query = id(new PhabricatorEditEngineConfigurationQuery())->setViewer($viewer)->withEngineKeys(array($engine->getEngineKey()));
     if ($is_create) {
         $query->withIsDefault(true);
     } else {
         $query->withIsEdit(true);
     }
     $configs = $query->execute();
     // Do this check here (instead of in the Query above) to get a proper
     // policy exception if the user doesn't satisfy
     foreach ($configs as $config) {
         PhabricatorPolicyFilter::requireCapability($viewer, $config, PhabricatorPolicyCapability::CAN_EDIT);
     }
     if ($is_create) {
         $configs = msort($configs, 'getCreateSortKey');
     } else {
         $configs = msort($configs, 'getEditSortKey');
     }
     if ($request->isFormPost()) {
         $form_order = $request->getStrList('formOrder');
         // NOTE: This has a side-effect of saving any factory-default forms
         // to the database. We might want to warn the user better, but this
         // shouldn't generally be very important or confusing.
         $configs = mpull($configs, null, 'getIdentifier');
         $configs = array_select_keys($configs, $form_order) + $configs;
         $order = 1;
         foreach ($configs as $config) {
             $xactions = array();
             if ($is_create) {
                 $xaction_type = PhabricatorEditEngineConfigurationTransaction::TYPE_CREATEORDER;
             } else {
                 $xaction_type = PhabricatorEditEngineConfigurationTransaction::TYPE_EDITORDER;
             }
             $xactions[] = id(new PhabricatorEditEngineConfigurationTransaction())->setTransactionType($xaction_type)->setNewValue($order);
             $editor = id(new PhabricatorEditEngineConfigurationEditor())->setActor($viewer)->setContentSourceFromRequest($request)->setContinueOnNoEffect(true);
             $editor->applyTransactions($config, $xactions);
             $order++;
         }
         return id(new AphrontRedirectResponse())->setURI($cancel_uri);
     }
     $list_id = celerity_generate_unique_node_id();
     $input_id = celerity_generate_unique_node_id();
     $list = id(new PHUIObjectItemListView())->setUser($viewer)->setID($list_id)->setFlush(true);
     $form_order = array();
     foreach ($configs as $config) {
         $name = $config->getName();
         $identifier = $config->getIdentifier();
         $item = id(new PHUIObjectItemView())->setHeader($name)->setGrippable(true)->addSigil('editengine-form-config')->setMetadata(array('formIdentifier' => $identifier));
         $list->addItem($item);
         $form_order[] = $identifier;
     }
     Javelin::initBehavior('editengine-reorder-configs', array('listID' => $list_id, 'inputID' => $input_id, 'reorderURI' => $reorder_uri));
     if ($is_create) {
         $title = pht('Reorder Create Forms');
         $button = pht('Save Create Order');
         $note_text = pht('Drag and drop fields to change the order in which they appear in ' . 'the application "Create" menu.');
     } else {
         $title = pht('Reorder Edit Forms');
         $button = pht('Save Edit Order');
         $note_text = pht('Drag and drop fields to change their priority for edits. When a ' . 'user edits an object, they will be shown the first form in this ' . 'list that they have permission to see.');
     }
     $note = id(new PHUIInfoView())->appendChild($note_text)->setSeverity(PHUIInfoView::SEVERITY_NOTICE);
     $input = phutil_tag('input', array('type' => 'hidden', 'name' => 'formOrder', 'value' => implode(', ', $form_order), 'id' => $input_id));
     return $this->newDialog()->setTitle($title)->setWidth(AphrontDialogView::WIDTH_FORM)->appendChild($note)->appendChild($list)->appendChild($input)->addSubmitButton(pht('Save Changes'))->addCancelButton($cancel_uri);
 }
開發者ID:alexlis,項目名稱:phabricator,代碼行數:77,代碼來源:PhabricatorEditEngineConfigurationSortController.php

示例8: processDiffusionRequest

 protected function processDiffusionRequest(AphrontRequest $request)
 {
     $viewer = $request->getUser();
     $drequest = $this->diffusionRequest;
     $repository = $drequest->getRepository();
     PhabricatorPolicyFilter::requireCapability($viewer, $repository, PhabricatorPolicyCapability::CAN_EDIT);
     if ($request->getURIData('id')) {
         $mirror = id(new PhabricatorRepositoryMirrorQuery())->setViewer($viewer)->withIDs(array($request->getURIData('id')))->requireCapabilities(array(PhabricatorPolicyCapability::CAN_VIEW, PhabricatorPolicyCapability::CAN_EDIT))->executeOne();
         if (!$mirror) {
             return new Aphront404Response();
         }
         $is_new = false;
     } else {
         $mirror = PhabricatorRepositoryMirror::initializeNewMirror($viewer)->setRepositoryPHID($repository->getPHID())->attachRepository($repository);
         $is_new = true;
     }
     $edit_uri = $this->getRepositoryControllerURI($repository, 'edit/#mirrors');
     $v_remote = $mirror->getRemoteURI();
     $e_remote = true;
     $v_credentials = $mirror->getCredentialPHID();
     $e_credentials = null;
     $credentials = id(new PassphraseCredentialQuery())->setViewer($viewer)->withIsDestroyed(false)->execute();
     $errors = array();
     if ($request->isFormPost()) {
         $v_remote = $request->getStr('remoteURI');
         if (strlen($v_remote)) {
             try {
                 PhabricatorRepository::assertValidRemoteURI($v_remote);
                 $e_remote = null;
             } catch (Exception $ex) {
                 $e_remote = pht('Invalid');
                 $errors[] = $ex->getMessage();
             }
         } else {
             $e_remote = pht('Required');
             $errors[] = pht('You must provide a remote URI.');
         }
         $v_credentials = $request->getStr('credential');
         if ($v_credentials) {
             $phids = mpull($credentials, null, 'getPHID');
             if (empty($phids[$v_credentials])) {
                 $e_credentials = pht('Invalid');
                 $errors[] = pht('You do not have permission to use those credentials.');
             }
         }
         if (!$errors) {
             $mirror->setRemoteURI($v_remote)->setCredentialPHID($v_credentials)->save();
             return id(new AphrontReloadResponse())->setURI($edit_uri);
         }
     }
     $form_errors = null;
     if ($errors) {
         $form_errors = id(new PHUIInfoView())->setErrors($errors);
     }
     if ($is_new) {
         $title = pht('Create Mirror');
         $submit = pht('Create Mirror');
     } else {
         $title = pht('Edit Mirror');
         $submit = pht('Save Changes');
     }
     $form = id(new PHUIFormLayoutView())->appendChild(id(new AphrontFormTextControl())->setLabel(pht('Remote URI'))->setName('remoteURI')->setValue($v_remote)->setError($e_remote))->appendChild(id(new PassphraseCredentialControl())->setLabel(pht('Credentials'))->setName('credential')->setAllowNull(true)->setValue($v_credentials)->setError($e_credentials)->setOptions($credentials));
     $dialog = id(new AphrontDialogView())->setUser($viewer)->setTitle($title)->setWidth(AphrontDialogView::WIDTH_FORM)->appendChild($form_errors)->appendChild($form)->addSubmitButton($submit)->addCancelButton($edit_uri);
     return id(new AphrontDialogResponse())->setDialog($dialog);
 }
開發者ID:patelhardik,項目名稱:phabricator,代碼行數:65,代碼來源:DiffusionMirrorEditController.php

示例9: processRequest

 public function processRequest()
 {
     $request = $this->getRequest();
     $viewer = $request->getUser();
     $authority = $this->loadMerchantAuthority();
     $cart_query = id(new PhortuneCartQuery())->setViewer($viewer)->withIDs(array($this->id))->needPurchases(true);
     if ($authority) {
         $cart_query->withMerchantPHIDs(array($authority->getPHID()));
     }
     $cart = $cart_query->executeOne();
     if (!$cart) {
         return new Aphront404Response();
     }
     switch ($this->action) {
         case 'cancel':
             // You must be able to edit the account to cancel an order.
             PhabricatorPolicyFilter::requireCapability($viewer, $cart->getAccount(), PhabricatorPolicyCapability::CAN_EDIT);
             $is_refund = false;
             break;
         case 'refund':
             // You must be able to control the merchant to refund an order.
             PhabricatorPolicyFilter::requireCapability($viewer, $cart->getMerchant(), PhabricatorPolicyCapability::CAN_EDIT);
             $is_refund = true;
             break;
         default:
             return new Aphront404Response();
     }
     $cancel_uri = $cart->getDetailURI($authority);
     $merchant = $cart->getMerchant();
     try {
         if ($is_refund) {
             $title = pht('Unable to Refund Order');
             $cart->assertCanRefundOrder();
         } else {
             $title = pht('Unable to Cancel Order');
             $cart->assertCanCancelOrder();
         }
     } catch (Exception $ex) {
         return $this->newDialog()->setTitle($title)->appendChild($ex->getMessage())->addCancelButton($cancel_uri);
     }
     $charges = id(new PhortuneChargeQuery())->setViewer($viewer)->withCartPHIDs(array($cart->getPHID()))->withStatuses(array(PhortuneCharge::STATUS_HOLD, PhortuneCharge::STATUS_CHARGED))->execute();
     $amounts = mpull($charges, 'getAmountAsCurrency');
     $maximum = PhortuneCurrency::newFromList($amounts);
     $v_refund = $maximum->formatForDisplay();
     $errors = array();
     $e_refund = true;
     if ($request->isFormPost()) {
         if ($is_refund) {
             try {
                 $refund = PhortuneCurrency::newFromUserInput($viewer, $request->getStr('refund'));
                 $refund->assertInRange('0.00 USD', $maximum->formatForDisplay());
             } catch (Exception $ex) {
                 $errors[] = $ex->getMessage();
                 $e_refund = pht('Invalid');
             }
         } else {
             $refund = $maximum;
         }
         if (!$errors) {
             $charges = msort($charges, 'getID');
             $charges = array_reverse($charges);
             if ($charges) {
                 $providers = id(new PhortunePaymentProviderConfigQuery())->setViewer($viewer)->withPHIDs(mpull($charges, 'getProviderPHID'))->execute();
                 $providers = mpull($providers, null, 'getPHID');
             } else {
                 $providers = array();
             }
             foreach ($charges as $charge) {
                 $refundable = $charge->getAmountRefundableAsCurrency();
                 if (!$refundable->isPositive()) {
                     // This charge is a refund, or has already been fully refunded.
                     continue;
                 }
                 if ($refund->isGreaterThan($refundable)) {
                     $refund_amount = $refundable;
                 } else {
                     $refund_amount = $refund;
                 }
                 $provider_config = idx($providers, $charge->getProviderPHID());
                 if (!$provider_config) {
                     throw new Exception(pht('Unable to load provider for charge!'));
                 }
                 $provider = $provider_config->buildProvider();
                 $refund_charge = $cart->willRefundCharge($viewer, $provider, $charge, $refund_amount);
                 $refunded = false;
                 try {
                     $provider->refundCharge($charge, $refund_charge);
                     $refunded = true;
                 } catch (Exception $ex) {
                     phlog($ex);
                     $cart->didFailRefund($charge, $refund_charge);
                 }
                 if ($refunded) {
                     $cart->didRefundCharge($charge, $refund_charge);
                     $refund = $refund->subtract($refund_amount);
                 }
                 if (!$refund->isPositive()) {
                     break;
                 }
             }
//.........這裏部分代碼省略.........
開發者ID:hrb518,項目名稱:phabricator,代碼行數:101,代碼來源:PhortuneCartCancelController.php

示例10: requireCapabilities

 protected function requireCapabilities(PhabricatorLiskDAO $object, PhabricatorApplicationTransaction $xaction)
 {
     switch ($xaction->getTransactionType()) {
         case PhabricatorProjectColumnTransaction::TYPE_NAME:
         case PhabricatorProjectColumnTransaction::TYPE_STATUS:
             PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
             return;
     }
     return parent::requireCapabilities($object, $xaction);
 }
開發者ID:rchicoli,項目名稱:phabricator,代碼行數:10,代碼來源:PhabricatorProjectColumnTransactionEditor.php

示例11: validateEdit

 /**
  * Validate that the edit is permissible, and the actor has permission to
  * perform it.
  */
 private function validateEdit(PhabricatorApplicationTransaction $xaction, PhabricatorApplicationTransactionComment $comment)
 {
     if (!$xaction->getPHID()) {
         throw new Exception(pht('Transaction must have a PHID before calling %s!', 'applyEdit()'));
     }
     $type_comment = PhabricatorTransactions::TYPE_COMMENT;
     if ($xaction->getTransactionType() == $type_comment) {
         if ($comment->getPHID()) {
             throw new Exception(pht('Transaction comment must not yet have a PHID!'));
         }
     }
     if (!$this->getContentSource()) {
         throw new PhutilInvalidStateException('applyEdit');
     }
     $actor = $this->requireActor();
     PhabricatorPolicyFilter::requireCapability($actor, $xaction, PhabricatorPolicyCapability::CAN_VIEW);
     if ($comment->getIsRemoved() && $actor->getIsAdmin()) {
         // NOTE: Administrators can remove comments by any user, and don't need
         // to pass the edit check.
     } else {
         PhabricatorPolicyFilter::requireCapability($actor, $xaction, PhabricatorPolicyCapability::CAN_EDIT);
     }
 }
開發者ID:rchicoli,項目名稱:phabricator,代碼行數:27,代碼來源:PhabricatorApplicationTransactionCommentEditor.php

示例12: requireCapabilities

 protected function requireCapabilities(PhabricatorLiskDAO $object, PhabricatorApplicationTransaction $xaction)
 {
     switch ($xaction->getTransactionType()) {
         case PhabricatorProjectTransaction::TYPE_NAME:
         case PhabricatorProjectTransaction::TYPE_STATUS:
         case PhabricatorProjectTransaction::TYPE_IMAGE:
         case PhabricatorProjectTransaction::TYPE_ICON:
         case PhabricatorProjectTransaction::TYPE_COLOR:
             PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
             return;
         case PhabricatorProjectTransaction::TYPE_LOCKED:
             PhabricatorPolicyFilter::requireCapability($this->requireActor(), newv($this->getEditorApplicationClass(), array()), ProjectCanLockProjectsCapability::CAPABILITY);
             return;
         case PhabricatorTransactions::TYPE_EDGE:
             switch ($xaction->getMetadataValue('edge:type')) {
                 case PhabricatorProjectProjectHasMemberEdgeType::EDGECONST:
                     $old = $xaction->getOldValue();
                     $new = $xaction->getNewValue();
                     $add = array_keys(array_diff_key($new, $old));
                     $rem = array_keys(array_diff_key($old, $new));
                     $actor_phid = $this->requireActor()->getPHID();
                     $is_join = $add === array($actor_phid) && !$rem;
                     $is_leave = $rem === array($actor_phid) && !$add;
                     if ($is_join) {
                         // You need CAN_JOIN to join a project.
                         PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_JOIN);
                     } else {
                         if ($is_leave) {
                             // You usually don't need any capabilities to leave a project.
                             if ($object->getIsMembershipLocked()) {
                                 // you must be able to edit though to leave locked projects
                                 PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
                             }
                         } else {
                             // You need CAN_EDIT to change members other than yourself.
                             PhabricatorPolicyFilter::requireCapability($this->requireActor(), $object, PhabricatorPolicyCapability::CAN_EDIT);
                         }
                     }
                     return;
             }
             break;
     }
     return parent::requireCapabilities($object, $xaction);
 }
開發者ID:jvlstudio,項目名稱:phabricator,代碼行數:44,代碼來源:PhabricatorProjectTransactionEditor.php

示例13: processRequest

 public function processRequest()
 {
     $request = $this->getRequest();
     $viewer = $request->getUser();
     $drequest = $this->diffusionRequest;
     $repository = $drequest->getRepository();
     PhabricatorPolicyFilter::requireCapability($viewer, $repository, PhabricatorPolicyCapability::CAN_EDIT);
     $is_svn = false;
     $is_git = false;
     $is_hg = false;
     switch ($repository->getVersionControlSystem()) {
         case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
             $is_git = true;
             break;
         case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
             $is_svn = true;
             break;
         case PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL:
             $is_hg = true;
             break;
     }
     $has_branches = $is_git || $is_hg;
     $has_local = $repository->usesLocalWorkingCopy();
     $crumbs = $this->buildApplicationCrumbs($is_main = true);
     $title = pht('Edit %s', $repository->getName());
     $header = id(new PHUIHeaderView())->setHeader($title);
     if ($repository->isTracked()) {
         $header->setStatus('fa-check', 'bluegrey', pht('Active'));
     } else {
         $header->setStatus('fa-ban', 'dark', pht('Inactive'));
     }
     $basic_actions = $this->buildBasicActions($repository);
     $basic_properties = $this->buildBasicProperties($repository, $basic_actions);
     $policy_actions = $this->buildPolicyActions($repository);
     $policy_properties = $this->buildPolicyProperties($repository, $policy_actions);
     $remote_properties = null;
     if (!$repository->isHosted()) {
         $remote_properties = $this->buildRemoteProperties($repository, $this->buildRemoteActions($repository));
     }
     $encoding_actions = $this->buildEncodingActions($repository);
     $encoding_properties = $this->buildEncodingProperties($repository, $encoding_actions);
     $hosting_properties = $this->buildHostingProperties($repository, $this->buildHostingActions($repository));
     $branches_properties = null;
     if ($has_branches) {
         $branches_properties = $this->buildBranchesProperties($repository, $this->buildBranchesActions($repository));
     }
     $subversion_properties = null;
     if ($is_svn) {
         $subversion_properties = $this->buildSubversionProperties($repository, $this->buildSubversionActions($repository));
     }
     $local_properties = null;
     if ($has_local) {
         $local_properties = $this->buildLocalProperties($repository, $this->buildLocalActions($repository));
     }
     $actions_properties = $this->buildActionsProperties($repository, $this->buildActionsActions($repository));
     $xactions = id(new PhabricatorRepositoryTransactionQuery())->setViewer($viewer)->withObjectPHIDs(array($repository->getPHID()))->execute();
     $engine = id(new PhabricatorMarkupEngine())->setViewer($viewer);
     foreach ($xactions as $xaction) {
         if ($xaction->getComment()) {
             $engine->addObject($xaction->getComment(), PhabricatorApplicationTransactionComment::MARKUP_FIELD_COMMENT);
         }
     }
     $engine->process();
     $xaction_view = id(new PhabricatorApplicationTransactionView())->setUser($viewer)->setObjectPHID($repository->getPHID())->setTransactions($xactions)->setMarkupEngine($engine);
     $boxes = array();
     $boxes[] = id(new PHUIObjectBoxView())->setHeader($header)->addPropertyList($basic_properties);
     $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Policies'))->addPropertyList($policy_properties);
     $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Hosting'))->addPropertyList($hosting_properties);
     if ($repository->canMirror()) {
         $mirror_actions = $this->buildMirrorActions($repository);
         $mirror_properties = $this->buildMirrorProperties($repository, $mirror_actions);
         $mirrors = id(new PhabricatorRepositoryMirrorQuery())->setViewer($viewer)->withRepositoryPHIDs(array($repository->getPHID()))->execute();
         $mirror_list = $this->buildMirrorList($repository, $mirrors);
         $boxes[] = id(new PhabricatorAnchorView())->setAnchorName('mirrors');
         $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Mirrors'))->addPropertyList($mirror_properties);
         $boxes[] = $mirror_list;
     }
     if ($remote_properties) {
         $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Remote'))->addPropertyList($remote_properties);
     }
     if ($local_properties) {
         $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Local'))->addPropertyList($local_properties);
     }
     $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Text Encoding'))->addPropertyList($encoding_properties);
     if ($branches_properties) {
         $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Branches'))->addPropertyList($branches_properties);
     }
     if ($subversion_properties) {
         $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Subversion'))->addPropertyList($subversion_properties);
     }
     $boxes[] = id(new PHUIObjectBoxView())->setHeaderText(pht('Actions'))->addPropertyList($actions_properties);
     return $this->buildApplicationPage(array($crumbs, $boxes, $xaction_view), array('title' => $title));
 }
開發者ID:denghp,項目名稱:phabricator,代碼行數:93,代碼來源:DiffusionRepositoryEditMainController.php

示例14: buildPanelHideContent

 private function buildPanelHideContent(PhabricatorProfilePanelConfiguration $configuration)
 {
     $controller = $this->getController();
     $request = $controller->getRequest();
     $viewer = $this->getViewer();
     PhabricatorPolicyFilter::requireCapability($viewer, $configuration, PhabricatorPolicyCapability::CAN_EDIT);
     $v_visibility = $configuration->getVisibility();
     if ($request->isFormPost()) {
         $v_visibility = $request->getStr('visibility');
         $type_visibility = PhabricatorProfilePanelConfigurationTransaction::TYPE_VISIBILITY;
         $xactions = array();
         $xactions[] = id(new PhabricatorProfilePanelConfigurationTransaction())->setTransactionType($type_visibility)->setNewValue($v_visibility);
         $editor = id(new PhabricatorProfilePanelEditor())->setContentSourceFromRequest($request)->setActor($viewer)->setContinueOnMissingFields(true)->setContinueOnNoEffect(true)->applyTransactions($configuration, $xactions);
         return id(new AphrontRedirectResponse())->setURI($this->getConfigureURI());
     }
     $map = PhabricatorProfilePanelConfiguration::getVisibilityNameMap();
     $form = id(new AphrontFormView())->setUser($viewer)->appendControl(id(new AphrontFormSelectControl())->setName('visibility')->setLabel(pht('Visibility'))->setValue($v_visibility)->setOptions($map));
     return $controller->newDialog()->setTitle(pht('Change Item Visibility'))->appendForm($form)->addCancelButton($this->getConfigureURI())->addSubmitButton(pht('Save Changes'));
 }
開發者ID:jvlstudio,項目名稱:phabricator,代碼行數:19,代碼來源:PhabricatorProfilePanelEngine.php

示例15: assertCanIssueCommand

 public function assertCanIssueCommand(PhabricatorUser $viewer, $command)
 {
     $need_edit = false;
     switch ($command) {
         case HarbormasterBuildCommand::COMMAND_RESTART:
             break;
         case HarbormasterBuildCommand::COMMAND_PAUSE:
         case HarbormasterBuildCommand::COMMAND_RESUME:
         case HarbormasterBuildCommand::COMMAND_ABORT:
             $need_edit = true;
             break;
         default:
             throw new Exception(pht('Invalid Harbormaster build command "%s".', $command));
     }
     // Issuing these commands requires that you be able to edit the build, to
     // prevent enemy engineers from sabotaging your builds. See T9614.
     if ($need_edit) {
         PhabricatorPolicyFilter::requireCapability($viewer, $this->getBuildPlan(), PhabricatorPolicyCapability::CAN_EDIT);
     }
 }
開發者ID:rchicoli,項目名稱:phabricator,代碼行數:20,代碼來源:HarbormasterBuild.php


注:本文中的PhabricatorPolicyFilter::requireCapability方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。