当前位置: 首页>>代码示例>>PHP>>正文


PHP Property::validate方法代码示例

本文整理汇总了PHP中Sabre\VObject\Property::validate方法的典型用法代码示例。如果您正苦于以下问题:PHP Property::validate方法的具体用法?PHP Property::validate怎么用?PHP Property::validate使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Sabre\VObject\Property的用法示例。


在下文中一共展示了Property::validate方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。

示例1: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   - Node::REPAIR - If something is broken, and automatic repair may
  *                    be attempted.
  *
  * An array is returned with warnings.
  *
  * Every item in the array has the following properties:
  *    * level - (number between 1 and 3 with severity information)
  *    * message - (human readable message)
  *    * node - (reference to the offending node)
  *
  * @param int $options
  * @return array
  */
 public function validate($options = 0)
 {
     $warnings = parent::validate($options);
     if (isset($this->minimumPropertyValues[$this->name])) {
         $minimum = $this->minimumPropertyValues[$this->name];
         $parts = $this->getParts();
         if (count($parts) < $minimum) {
             $warnings[] = array('level' => 1, 'message' => 'This property must have at least ' . $minimum . ' components. It only has ' . count($parts), 'node' => $this);
             if ($options & self::REPAIR) {
                 $parts = array_pad($parts, $minimum, '');
                 $this->setParts($parts);
             }
         }
     }
     return $warnings;
 }
开发者ID:pkdevboxy,项目名称:webmail-lite,代码行数:33,代码来源:Text.php

示例2: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   Node::REPAIR - May attempt to automatically repair the problem.
  *
  * This method returns an array with detected problems.
  * Every element has the following properties:
  *
  *  * level - problem level.
  *  * message - A human-readable string describing the issue.
  *  * node - A reference to the problematic node.
  *
  * The level means:
  *   1 - The issue was repaired (only happens if REPAIR was turned on)
  *   2 - An inconsequential issue
  *   3 - A severe issue.
  *
  * @param int $options
  * @return array
  */
 public function validate($options = 0)
 {
     $messages = parent::validate($options);
     $value = $this->getValue();
     try {
         DateTimeParser::parseVCardDateTime($value);
     } catch (\InvalidArgumentException $e) {
         $messages[] = array('level' => 3, 'message' => 'The supplied value (' . $value . ') is not a correct DATE-AND-OR-TIME property', 'node' => $this);
     }
     return $messages;
 }
开发者ID:zhuomingliang,项目名称:webmail-lite,代码行数:32,代码来源:DateAndOrTime.php

示例3: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   Node::REPAIR - May attempt to automatically repair the problem.
  *
  * This method returns an array with detected problems.
  * Every element has the following properties:
  *
  *  * level - problem level.
  *  * message - A human-readable string describing the issue.
  *  * node - A reference to the problematic node.
  *
  * The level means:
  *   1 - The issue was repaired (only happens if REPAIR was turned on)
  *   2 - An inconsequential issue
  *   3 - A severe issue.
  *
  * @param int $options
  *
  * @return array
  */
 function validate($options = 0)
 {
     $messages = parent::validate($options);
     $valueType = $this->getValueType();
     $values = $this->getParts();
     try {
         foreach ($values as $value) {
             switch ($valueType) {
                 case 'DATE':
                     DateTimeParser::parseDate($value);
                     break;
                 case 'DATE-TIME':
                     DateTimeParser::parseDateTime($value);
                     break;
             }
         }
     } catch (InvalidDataException $e) {
         $messages[] = ['level' => 3, 'message' => 'The supplied value (' . $value . ') is not a correct ' . $valueType, 'node' => $this];
     }
     return $messages;
 }
开发者ID:linagora,项目名称:sabre-vobject,代码行数:43,代码来源:DateTime.php

示例4: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   Node::REPAIR - May attempt to automatically repair the problem.
  *
  * This method returns an array with detected problems.
  * Every element has the following properties:
  *
  *  * level - problem level.
  *  * message - A human-readable string describing the issue.
  *  * node - A reference to the problematic node.
  *
  * The level means:
  *   1 - The issue was repaired (only happens if REPAIR was turned on)
  *   2 - An inconsequential issue
  *   3 - A severe issue.
  *
  * @param int $options
  * @return array
  */
 public function validate($options = 0)
 {
     $messages = parent::validate($options);
     $valueType = $this->getValueType();
     $value = $this->getValue();
     try {
         switch ($valueType) {
             case 'DATE':
                 $foo = DateTimeParser::parseDate($value);
                 break;
             case 'DATE-TIME':
                 $foo = DateTimeParser::parseDateTime($value);
                 break;
         }
     } catch (\LogicException $e) {
         $messages[] = array('level' => 3, 'message' => 'The supplied value (' . $value . ') is not a correct ' . $valueType, 'node' => $this);
     }
     return $messages;
 }
开发者ID:MetallianFR68,项目名称:myroundcube,代码行数:40,代码来源:DateTime.php

示例5: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   Node::REPAIR - May attempt to automatically repair the problem.
  *
  * This method returns an array with detected problems.
  * Every element has the following properties:
  *
  *  * level - problem level.
  *  * message - A human-readable string describing the issue.
  *  * node - A reference to the problematic node.
  *
  * The level means:
  *   1 - The issue was repaired (only happens if REPAIR was turned on)
  *   2 - An inconsequential issue
  *   3 - A severe issue.
  *
  * @param int $options
  *
  * @return array
  */
 function validate($options = 0)
 {
     $repair = $options & self::REPAIR;
     $warnings = parent::validate($options);
     $values = $this->getParts();
     foreach ($values as $key => $value) {
         if ($value === '') {
             $warnings[] = ['level' => $repair ? 1 : 3, 'message' => 'Invalid value for ' . $key . ' in ' . $this->name, 'node' => $this];
             if ($repair) {
                 unset($values[$key]);
             }
         } elseif ($key == 'BYMONTH') {
             $byMonth = (array) $value;
             foreach ($byMonth as $i => $v) {
                 if (!is_numeric($v) || (int) $v < 1 || (int) $v > 12) {
                     $warnings[] = ['level' => $repair ? 1 : 3, 'message' => 'BYMONTH in RRULE must have value(s) between 1 and 12!', 'node' => $this];
                     if ($repair) {
                         if (is_array($value)) {
                             unset($values[$key][$i]);
                         } else {
                             unset($values[$key]);
                         }
                     }
                 }
             }
         }
     }
     if (!isset($values['FREQ'])) {
         $warnings[] = ['level' => $repair ? 1 : 3, 'message' => 'FREQ is required in ' . $this->name, 'node' => $this];
         if ($repair) {
             $this->parent->remove($this);
         }
     }
     if ($repair) {
         $this->setValue($values);
     }
     return $warnings;
 }
开发者ID:Radiergummi,项目名称:anacronism,代码行数:60,代码来源:Recur.php

示例6: validate

 /**
  * Validates the node for correctness.
  *
  * The following options are supported:
  *   Node::REPAIR - May attempt to automatically repair the problem.
  *
  * This method returns an array with detected problems.
  * Every element has the following properties:
  *
  *  * level - problem level.
  *  * message - A human-readable string describing the issue.
  *  * node - A reference to the problematic node.
  *
  * The level means:
  *   1 - The issue was repaired (only happens if REPAIR was turned on)
  *   2 - An inconsequential issue
  *   3 - A severe issue.
  *
  * @param int $options
  *
  * @return array
  */
 function validate($options = 0)
 {
     $repair = $options & self::REPAIR;
     $warnings = parent::validate($options);
     $values = $this->getParts();
     foreach ($values as $key => $value) {
         if (empty($value)) {
             $warnings[] = ['level' => $repair ? 3 : 1, 'message' => 'Invalid value for ' . $key . ' in ' . $this->name, 'node' => $this];
             if ($repair) {
                 unset($values[$key]);
             }
         }
     }
     if (!isset($values['FREQ'])) {
         $warnings[] = ['level' => $repair ? 3 : 1, 'message' => 'FREQ is required in ' . $this->name, 'node' => $this];
         if ($repair) {
             $this->parent->remove($this);
         }
     }
     if ($repair) {
         $this->setValue($values);
     }
     return $warnings;
 }
开发者ID:BlaBlaNet,项目名称:hubzilla,代码行数:46,代码来源:Recur.php


注:本文中的Sabre\VObject\Property::validate方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。