Example #1
0
 /**
  * (PHP 5 &gt;= 5.1.0)<br/>
  * Receive update from subject
  * @link http://php.net/manual/en/splobserver.update.php
  * @param SplSubject $subject <p>
  * The <b>SplSubject</b> notifying the observer of an update.
  * </p>
  * @return void
  */
 public function update(SplSubject $subject)
 {
     $position = $subject->getCurrentLine();
     $params = $subject->getCurrentTransactionParameters();
     $result = $subject->getCurrentTransactionResult();
     if ($position == 0) {
         $this->knownResultHeaders = array_keys($result);
         $this->headers = array_unique(array_merge(array_keys($params), $this->knownResultHeaders));
         sort($this->headers);
         // Write headers
         fputcsv($this->file, $this->headers, $subject->getDelimiter(), $subject->getEnclosure());
     }
     $newLine = array_merge($params, $result);
     $this->inMemoryImage[] = $newLine;
     // Search for new header keys
     $newKeys = array_diff(array_keys($result), $this->knownResultHeaders);
     // Search for missing header keys
     $missingKeys = array_diff($this->knownResultHeaders, array_keys($result));
     // Set to empty missing keys values so fputcsv will generate empty columns
     foreach ($missingKeys as $missingKey) {
         $newLine[$missingKey] = '';
     }
     // Rewrite full memory image and file
     if ($newKeys) {
         rewind($this->file);
         // Add new headers
         $this->headers = array_unique(array_merge($this->headers, $newKeys));
         $this->knownResultHeaders = array_unique(array_merge($this->knownResultHeaders, $newKeys));
         // Rewrite headers
         sort($this->headers);
         fputcsv($this->file, $this->headers, $subject->getDelimiter(), $subject->getEnclosure());
         // Re -dump top file from in memory image
         foreach ($this->inMemoryImage as $newLine) {
             foreach ($this->knownResultHeaders as $header) {
                 // The new header was not present for this line
                 if (!isset($newLine[$header])) {
                     // Set to empty so fputcsv will generate empty columns
                     $newLine[$header] = '';
                 }
             }
             ksort($newLine);
             fputcsv($this->file, $newLine, $subject->getDelimiter(), $subject->getEnclosure());
         }
     } else {
         ksort($newLine);
         fputcsv($this->file, $newLine, $subject->getDelimiter(), $subject->getEnclosure());
     }
 }
Example #2
0
 /**
  * (PHP 5 &gt;= 5.1.0)<br/>
  * Receive update from subject
  * @link http://php.net/manual/en/splobserver.update.php
  * @param SplSubject $subject <p>
  * The <b>SplSubject</b> notifying the observer of an update.
  * </p>
  * @return void
  */
 public function update(SplSubject $subject)
 {
     $line = $subject->getCurrentLine() + 1;
     $params = $subject->getCurrentTransactionParameters();
     $result = $subject->getCurrentTransactionResult();
     $output = "Line {$line}";
     if (isset($params['ORDERID'])) {
         $output .= " (ORDERID={$params['ORDERID']})";
     }
     $output .= ' :';
     if (isset($result['EXECCODE'])) {
         $output .= " EXECCODE={$result['EXECCODE']}";
     }
     if (isset($result['MESSAGE'])) {
         $output .= " MESSAGE={$result['MESSAGE']}";
     }
     if (isset($result['TRANSACTIONID'])) {
         $output .= " TRANSACTIONID={$result['TRANSACTIONID']}";
     }
     $output .= "\n";
     echo $output;
 }