TypeError: function_exists(): Argument #1 ($function) must be of type string, array given in function_exists()

Created on 4 March 2025, about 1 month ago

Problem/Motivation

I am not sure, if this issue is related to Commerce Promotion or Drupal Core. The error is pointing to Drupal core options.module. Just a note this website, is migrated from Drupal 7. and I am using Commerce version 3.

It seems, while showing promotion list, the function expect a string but got an array. When I debug, it shows this:

 array:2 [โ–ผ
  0 => "Drupal\commerce_promotion\Entity\Promotion"
  1 => "getOfferOptions"
]

Steps to reproduce

When I tried to visit the url "/admin/commerce/promotions", the page breaks and show the error with this detail:

TypeError: function_exists(): Argument #1 ($function) must be of type string, array given in function_exists() (line 90 of core\modules\options\options.module).
options_allowed_values(Object) (Line: 29)
Drupal\options\Plugin\views\filter\ListField->init(Object, Object, Array) (Line: 902)
Drupal\views\Plugin\views\display\DisplayPluginBase->getHandlers('filter') (Line: 1100)
Drupal\views\ViewExecutable->_initHandler('filter', Array) (Line: 958)
Drupal\views\ViewExecutable->initHandlers() (Line: 2326)
Drupal\views\Plugin\views\display\DisplayPluginBase->preExecute() (Line: 1752)
Drupal\views\ViewExecutable->preExecute(Array) (Line: 1687)
Drupal\views\ViewExecutable->executeDisplay('admin', Array) (Line: 81)
Drupal\views\Element\View::preRenderViewElement(Array)
call_user_func_array(Array, Array) (Line: 113)
Drupal\Core\Render\Renderer->doTrustedCallback(Array, Array, 'Render #pre_render callbacks must be methods of a class that implements \Drupal\Core\Security\TrustedCallbackInterface or be an anonymous function. The callback was %s. See https://www.drupal.org/node/2966725', 'exception', 'Drupal\Core\Render\Element\RenderCallbackInterface') (Line: 870)
Drupal\Core\Render\Renderer->doCallback('#pre_render', Array, Array) (Line: 432)
Drupal\Core\Render\Renderer->doRender(Array, ) (Line: 248)
Drupal\Core\Render\Renderer->render(Array, ) (Line: 238)
Drupal\Core\Render\MainContent\HtmlRenderer->Drupal\Core\Render\MainContent\{closure}() (Line: 638)
Drupal\Core\Render\Renderer->executeInRenderContext(Object, Object) (Line: 231)
Drupal\Core\Render\MainContent\HtmlRenderer->prepare(Array, Object, Object) (Line: 128)
Drupal\Core\Render\MainContent\HtmlRenderer->renderResponse(Array, Object, Object) (Line: 90)
Drupal\Core\EventSubscriber\MainContentViewSubscriber->onViewRenderArray(Object, 'kernel.view', Object)
call_user_func(Array, Object, 'kernel.view', Object) (Line: 111)
Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch(Object, 'kernel.view') (Line: 186)
Symfony\Component\HttpKernel\HttpKernel->handleRaw(Object, 1) (Line: 76)
Symfony\Component\HttpKernel\HttpKernel->handle(Object, 1, 1) (Line: 53)
Drupal\Core\StackMiddleware\Session->handle(Object, 1, 1) (Line: 48)
Drupal\Core\StackMiddleware\KernelPreHandle->handle(Object, 1, 1) (Line: 28)
Drupal\Core\StackMiddleware\ContentLength->handle(Object, 1, 1) (Line: 32)
Drupal\big_pipe\StackMiddleware\ContentLength->handle(Object, 1, 1) (Line: 116)
Drupal\page_cache\StackMiddleware\PageCache->pass(Object, 1, 1) (Line: 90)
Drupal\page_cache\StackMiddleware\PageCache->handle(Object, 1, 1) (Line: 48)
Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle(Object, 1, 1) (Line: 51)
Drupal\Core\StackMiddleware\NegotiationMiddleware->handle(Object, 1, 1) (Line: 36)
Drupal\Core\StackMiddleware\AjaxPageState->handle(Object, 1, 1) (Line: 51)
Drupal\Core\StackMiddleware\StackedHttpKernel->handle(Object, 1, 1) (Line: 741)
Drupal\Core\DrupalKernel->handle(Object) (Line: 19)

Proposed resolution

We might check, if $function is an array or string. If string, we can call directly otherwise call the function inside the class

๐Ÿ› Bug report
Status

Active

Version

10.4 โœจ

Component

options.module

Created by

๐Ÿ‡ง๐Ÿ‡ฉBangladesh shafiqhossain

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Production build 0.71.5 2024