Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php final class HarbormasterBuildLogDownloadController extends HarbormasterController..

Decoded Output download

<?php

final class HarbormasterBuildLogDownloadController
  extends HarbormasterController {

  public function shouldAllowPublic() {
    return true;
  }

  public function handleRequest(AphrontRequest $request) {
    $request = $this->getRequest();
    $viewer = $request->getUser();

    $id = $request->getURIData('id');

    $log = id(new HarbormasterBuildLogQuery())
      ->setViewer($viewer)
      ->withIDs(array($id))
      ->executeOne();
    if (!$log) {
      return new Aphront404Response();
    }

    $cancel_uri = $log->getURI();
    $file_phid = $log->getFilePHID();

    if (!$file_phid) {
      return $this->newDialog()
        ->setTitle(pht('Log Not Finalized'))
        ->appendParagraph(
          pht(
            'Logs must be fully written and processed before they can be '.
            'downloaded. This log is still being written or processed.'))
        ->addCancelButton($cancel_uri, pht('Wait Patiently'));
    }

    $file = id(new PhabricatorFileQuery())
      ->setViewer($viewer)
      ->withPHIDs(array($file_phid))
      ->executeOne();
    if (!$file) {
      return $this->newDialog()
        ->setTitle(pht('Unable to Load File'))
        ->appendParagraph(
          pht(
            'Unable to load the file for this log. The file may have been '.
            'destroyed.'))
        ->addCancelButton($cancel_uri);
    }

    return $file->newDownloadResponse();
  }

}
 ?>

Did this file decode correctly?

Original Code

<?php

final class HarbormasterBuildLogDownloadController
  extends HarbormasterController {

  public function shouldAllowPublic() {
    return true;
  }

  public function handleRequest(AphrontRequest $request) {
    $request = $this->getRequest();
    $viewer = $request->getUser();

    $id = $request->getURIData('id');

    $log = id(new HarbormasterBuildLogQuery())
      ->setViewer($viewer)
      ->withIDs(array($id))
      ->executeOne();
    if (!$log) {
      return new Aphront404Response();
    }

    $cancel_uri = $log->getURI();
    $file_phid = $log->getFilePHID();

    if (!$file_phid) {
      return $this->newDialog()
        ->setTitle(pht('Log Not Finalized'))
        ->appendParagraph(
          pht(
            'Logs must be fully written and processed before they can be '.
            'downloaded. This log is still being written or processed.'))
        ->addCancelButton($cancel_uri, pht('Wait Patiently'));
    }

    $file = id(new PhabricatorFileQuery())
      ->setViewer($viewer)
      ->withPHIDs(array($file_phid))
      ->executeOne();
    if (!$file) {
      return $this->newDialog()
        ->setTitle(pht('Unable to Load File'))
        ->appendParagraph(
          pht(
            'Unable to load the file for this log. The file may have been '.
            'destroyed.'))
        ->addCancelButton($cancel_uri);
    }

    return $file->newDownloadResponse();
  }

}

Function Calls

None

Variables

None

Stats

MD5 191e88cea0f16c6a46ea0186cf3595d0
Eval Count 0
Decode Time 120 ms