| Conditions | 11 | 
| Paths | 33 | 
| Total Lines | 95 | 
| Lines | 16 | 
| Ratio | 16.84 % | 
| Changes | 0 | ||
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
| 1 | <?php //phpcs:ignore WordPress.Files.FileName.InvalidClassFileName | ||
| 99 | 	public static function get() { | ||
| 100 | // this can be expensive to compute so we cache for the duration of a request. | ||
| 101 | 		if ( is_array( self::$active_plan_cache ) && ! empty( self::$active_plan_cache ) ) { | ||
| 102 | return self::$active_plan_cache; | ||
| 103 | } | ||
| 104 | |||
| 105 | $plan = get_option( self::PLAN_OPTION, array() ); | ||
| 106 | |||
| 107 | // Set the default options. | ||
| 108 | $plan = wp_parse_args( | ||
| 109 | $plan, | ||
| 110 | array( | ||
| 111 | 'product_slug' => 'jetpack_free', | ||
| 112 | 'class' => 'free', | ||
| 113 | 'features' => array( | ||
| 114 | 'active' => array(), | ||
| 115 | ), | ||
| 116 | ) | ||
| 117 | ); | ||
| 118 | |||
| 119 | $supports = array(); | ||
| 120 | |||
| 121 | // Define what paid modules are supported by personal plans. | ||
| 122 | $personal_plans = array( | ||
| 123 | 'jetpack_personal', | ||
| 124 | 'jetpack_personal_monthly', | ||
| 125 | 'personal-bundle', | ||
| 126 | 'personal-bundle-monthly', | ||
| 127 | 'personal-bundle-2y', | ||
| 128 | ); | ||
| 129 | |||
| 130 | 		if ( in_array( $plan['product_slug'], $personal_plans, true ) ) { | ||
| 131 | // special support value, not a module but a separate plugin. | ||
| 132 | $supports[] = 'akismet'; | ||
| 133 | $supports[] = 'recurring-payments'; | ||
| 134 | $plan['class'] = 'personal'; | ||
| 135 | } | ||
| 136 | |||
| 137 | // Define what paid modules are supported by premium plans. | ||
| 138 | $premium_plans = array( | ||
| 139 | 'jetpack_premium', | ||
| 140 | 'jetpack_premium_monthly', | ||
| 141 | 'value_bundle', | ||
| 142 | 'value_bundle-monthly', | ||
| 143 | 'value_bundle-2y', | ||
| 144 | ); | ||
| 145 | |||
| 146 | View Code Duplication | 		if ( in_array( $plan['product_slug'], $premium_plans, true ) ) { | |
| 147 | $supports[] = 'akismet'; | ||
| 148 | $supports[] = 'recurring-payments'; | ||
| 149 | $supports[] = 'simple-payments'; | ||
| 150 | $supports[] = 'vaultpress'; | ||
| 151 | $supports[] = 'videopress'; | ||
| 152 | $plan['class'] = 'premium'; | ||
| 153 | } | ||
| 154 | |||
| 155 | // Define what paid modules are supported by professional plans. | ||
| 156 | $business_plans = array( | ||
| 157 | 'jetpack_business', | ||
| 158 | 'jetpack_business_monthly', | ||
| 159 | 'business-bundle', | ||
| 160 | 'business-bundle-monthly', | ||
| 161 | 'business-bundle-2y', | ||
| 162 | 'ecommerce-bundle', | ||
| 163 | 'ecommerce-bundle-monthly', | ||
| 164 | 'ecommerce-bundle-2y', | ||
| 165 | 'vip', | ||
| 166 | ); | ||
| 167 | |||
| 168 | View Code Duplication | 		if ( in_array( $plan['product_slug'], $business_plans, true ) ) { | |
| 169 | $supports[] = 'akismet'; | ||
| 170 | $supports[] = 'recurring-payments'; | ||
| 171 | $supports[] = 'simple-payments'; | ||
| 172 | $supports[] = 'vaultpress'; | ||
| 173 | $supports[] = 'videopress'; | ||
| 174 | $plan['class'] = 'business'; | ||
| 175 | } | ||
| 176 | |||
| 177 | // get available features. | ||
| 178 | 		foreach ( Jetpack::get_available_modules() as $module_slug ) { | ||
| 179 | $module = Jetpack::get_module( $module_slug ); | ||
| 180 | 			if ( ! isset( $module ) || ! is_array( $module ) ) { | ||
| 181 | continue; | ||
| 182 | } | ||
| 183 | 			if ( in_array( 'free', $module['plan_classes'], true ) || in_array( $plan['class'], $module['plan_classes'], true ) ) { | ||
| 184 | $supports[] = $module_slug; | ||
| 185 | } | ||
| 186 | } | ||
| 187 | |||
| 188 | $plan['supports'] = $supports; | ||
| 189 | |||
| 190 | self::$active_plan_cache = $plan; | ||
| 191 | |||
| 192 | return $plan; | ||
| 193 | } | ||
| 194 | |||
| 232 | 
Our type inference engine has found an assignment to a property that is incompatible with the declared type of that property.
Either this assignment is in error or the assigned type should be added to the documentation/type hint for that property..