awcodes / filament-tiptap-editor

A Rich Text Editor plugin for Filament Forms.
MIT License
249 stars 64 forks source link

Large Content Throwing Exception (Exceeding Default max_execution_time of 30 Seconds) #417

Closed nxgcx closed 1 week ago

nxgcx commented 1 week ago

Filament Version

v3.2.39

Plugin Version

v3.4.1

PHP Version

v8.1.26

Problem description

When pasting in simple but long content via the "source code" button. The editor throws an exception (Maximum execution time of 30 seconds exceeded).

Expected behavior

It should process the content in a timely manner, maintaining responsiveness, and not throw any exceptions.

Steps to reproduce

Simply paste the test content provided below in to the editor using the "source code" button, click ok, then wait long enough and you will see a 500 error occurs due 30 seconds being exceeded. Note that 30 seconds is the default unchanged timeout limit for a PHP install by default and is used widely.

<h1>Main Heading</h1>
<h2>Subheading 1</h2>
<p>This is a paragraph under Subheading 1. Here are some links:</p>
<ul>
    <li><a href="#link1">Link 1</a></li>
    <li><a href="#link2">Link 2</a></li>
    <li><a href="#link3">Link 3</a></li>
    <li><a href="#link4">Link 4</a></li>
    <li><a href="#link5">Link 5</a></li>
    <li><a href="#link6">Link 6</a></li>
    <li><a href="#link7">Link 7</a></li>
    <li><a href="#link8">Link 8</a></li>
    <li><a href="#link9">Link 9</a></li>
    <li><a href="#link10">Link 10</a></li>
    <li><a href="#link11">Link 11</a></li>
    <li><a href="#link12">Link 12</a></li>
    <li><a href="#link13">Link 13</a></li>
    <li><a href="#link14">Link 14</a></li>
    <li><a href="#link15">Link 15</a></li>
    <li><a href="#link16">Link 16</a></li>
    <li><a href="#link17">Link 17</a></li>
    <li><a href="#link18">Link 18</a></li>
    <li><a href="#link19">Link 19</a></li>
    <li><a href="#link20">Link 20</a></li>
</ul>
<h2>Subheading 2</h2>
<p>This is a paragraph under Subheading 2. Here are some more links:</p>
<ul>
    <li><a href="#link21">Link 21</a></li>
    <li><a href="#link22">Link 22</a></li>
    <li><a href="#link23">Link 23</a></li>
    <li><a href="#link24">Link 24</a></li>
    <li><a href="#link25">Link 25</a></li>
    <li><a href="#link26">Link 26</a></li>
    <li><a href="#link27">Link 27</a></li>
    <li><a href="#link28">Link 28</a></li>
    <li><a href="#link29">Link 29</a></li>
    <li><a href="#link30">Link 30</a></li>
    <li><a href="#link31">Link 31</a></li>
    <li><a href="#link32">Link 32</a></li>
    <li><a href="#link33">Link 33</a></li>
    <li><a href="#link34">Link 34</a></li>
    <li><a href="#link35">Link 35</a></li>
    <li><a href="#link36">Link 36</a></li>
    <li><a href="#link37">Link 37</a></li>
    <li><a href="#link38">Link 38</a></li>
    <li><a href="#link39">Link 39</a></li>
    <li><a href="#link40">Link 40</a></li>
</ul>
<h2>Subheading 3</h2>
<p>This is a paragraph under Subheading 3. Here are even more links:</p>
<ul>
    <li><a href="#link41">Link 41</a></li>
    <li><a href="#link42">Link 42</a></li>
    <li><a href="#link43">Link 43</a></li>
    <li><a href="#link44">Link 44</a></li>
    <li><a href="#link45">Link 45</a></li>
    <li><a href="#link46">Link 46</a></li>
    <li><a href="#link47">Link 47</a></li>
    <li><a href="#link48">Link 48</a></li>
    <li><a href="#link49">Link 49</a></li>
    <li><a href="#link50">Link 50</a></li>
    <li><a href="#link51">Link 51</a></li>
    <li><a href="#link52">Link 52</a></li>
    <li><a href="#link53">Link 53</a></li>
    <li><a href="#link54">Link 54</a></li>
    <li><a href="#link55">Link 55</a></li>
    <li><a href="#link56">Link 56</a></li>
    <li><a href="#link57">Link 57</a></li>
    <li><a href="#link58">Link 58</a></li>
    <li><a href="#link59">Link 59</a></li>
    <li><a href="#link60">Link 60</a></li>
</ul>
<h2>Subheading 4</h2>
<p>This is a paragraph under Subheading 4. Yes, even more links:</p>
<ul>
    <li><a href="#link61">Link 61</a></li>
    <li><a href="#link62">Link 62</a></li>
    <li><a href="#link63">Link 63</a></li>
    <li><a href="#link64">Link 64</a></li>
    <li><a href="#link65">Link 65</a></li>
    <li><a href="#link66">Link 66</a></li>
    <li><a href="#link67">Link 67</a></li>
    <li><a href="#link68">Link 68</a></li>
    <li><a href="#link69">Link 69</a></li>
    <li><a href="#link70">Link 70</a></li>
    <li><a href="#link71">Link 71</a></li>
    <li><a href="#link72">Link 72</a></li>
    <li><a href="#link73">Link 73</a></li>
    <li><a href="#link74">Link 74</a></li>
    <li><a href="#link75">Link 75</a></li>
    <li><a href="#link76">Link 76</a></li>
    <li><a href="#link77">Link 77</a></li>
    <li><a href="#link78">Link 78</a></li>
    <li><a href="#link79">Link 79</a></li>
    <li><a href="#link80">Link 80</a></li>
</ul>
<h2>Subheading 5</h2>
<p>This is a paragraph under Subheading 5. More links to follow:</p>
<ul>
    <li><a href="#link81">Link 81</a></li>
    <li><a href="#link82">Link 82</a></li>
    <li><a href="#link83">Link 83</a></li>
    <li><a href="#link84">Link 84</a></li>
    <li><a href="#link85">Link 85</a></li>
    <li><a href="#link86">Link 86</a></li>
    <li><a href="#link87">Link 87</a></li>
    <li><a href="#link88">Link 88</a></li>
    <li><a href="#link89">Link 89</a></li>
    <li><a href="#link90">Link 90</a></li>
    <li><a href="#link91">Link 91</a></li>
    <li><a href="#link92">Link 92</a></li>
    <li><a href="#link93">Link 93</a></li>
    <li><a href="#link94">Link 94</a></li>
    <li><a href="#link95">Link 95</a></li>
    <li><a href="#link96">Link 96</a></li>
    <li><a href="#link97">Link 97</a></li>
    <li><a href="#link98">Link 98</a></li>
    <li><a href="#link99">Link 99</a></li>
    <li><a href="#link100">Link 100</a></li>
</ul>
<h2>Subheading 6</h2>
<p>This is a paragraph under Subheading 6. We're still going with more links:</p>
<ul>
    <li><a href="#link101">Link 101</a></li>
    <li><a href="#link102">Link 102</a></li>
    <li><a href="#link103">Link 103</a></li>
    <li><a href="#link104">Link 104</a></li>
    <li><a href="#link105">Link 105</a></li>
    <li><a href="#link106">Link 106</a></li>
    <li><a href="#link107">Link 107</a></li>
    <li><a href="#link108">Link 108</a></li>
    <li><a href="#link109">Link 109</a></li>
    <li><a href="#link110">Link 110</a></li>
    <li><a href="#link111">Link 111</a></li>
    <li><a href="#link112">Link 112</a></li>
    <li><a href="#link113">Link 113</a></li>
    <li><a href="#link114">Link 114</a></li>
    <li><a href="#link115">Link 115</a></li>
    <li><a href="#link116">Link 116</a></li>
    <li><a href="#link117">Link 117</a></li>
    <li><a href="#link118">Link 118</a></li>
    <li><a href="#link119">Link 119</a></li>
    <li><a href="#link120">Link 120</a></li>
</ul>
<h2>Subheading 7</h2>
<p>This is a paragraph under Subheading 7. Yes, more links:</p>
<ul>
    <li><a href="#link121">Link 121</a></li>
    <li><a href="#link122">Link 122</a></li>
    <li><a href="#link123">Link 123</a></li>
    <li><a href="#link124">Link 124</a></li>
    <li><a href="#link125">Link 125</a></li>
    <li><a href="#link126">Link 126</a></li>
    <li><a href="#link127">Link 127</a></li>
    <li><a href="#link128">Link 128</a></li>
    <li><a href="#link129">Link 129</a></li>
    <li><a href="#link130">Link 130</a></li>
    <li><a href="#link131">Link 131</a></li>
    <li><a href="#link132">Link 132</a></li>
    <li><a href="#link133">Link 133</a></li>
    <li><a href="#link134">Link 134</a></li>
    <li><a href="#link135">Link 135</a></li>
    <li><a href="#link136">Link 136</a></li>
    <li><a href="#link137">Link 137</a></li>
    <li><a href="#link138">Link 138</a></li>
    <li><a href="#link139">Link 139</a></li>
    <li><a href="#link140">Link 140</a></li>
</ul>
<h2>Subheading 8</h2>
<p>This is a paragraph under Subheading 8. More and more links:</p>
<ul>
    <li><a href="#link141">Link 141</a></li>
    <li><a href="#link142">Link 142</a></li>
    <li><a href="#link143">Link 143</a></li>
    <li><a href="#link144">Link 144</a></li>
    <li><a href="#link145">Link 145</a></li>
    <li><a href="#link146">Link 146</a></li>
    <li><a href="#link147">Link 147</a></li>
    <li><a href="#link148">Link 148</a></li>
    <li><a href="#link149">Link 149</a></li>
    <li><a href="#link150">Link 150</a></li>
    <li><a href="#link151">Link 151</a></li>
    <li><a href="#link152">Link 152</a></li>
    <li><a href="#link153">Link 153</a></li>
    <li><a href="#link154">Link 154</a></li>
    <li><a href="#link155">Link 155</a></li>
    <li><a href="#link156">Link 156</a></li>
    <li><a href="#link157">Link 157</a></li>
    <li><a href="#link158">Link 158</a></li>
    <li><a href="#link159">Link 159</a></li>
    <li><a href="#link160">Link 160</a></li>
</ul>
<h2>Subheading 9</h2>
<p>This is a paragraph under Subheading 9. Still going strong with links:</p>
<ul>
    <li><a href="#link161">Link 161</a></li>
    <li><a href="#link162">Link 162</a></li>
    <li><a href="#link163">Link 163</a></li>
    <li><a href="#link164">Link 164</a></li>
    <li><a href="#link165">Link 165</a></li>
    <li><a href="#link166">Link 166</a></li>
    <li><a href="#link167">Link 167</a></li>
    <li><a href="#link168">Link 168</a></li>
    <li><a href="#link169">Link 169</a></li>
    <li><a href="#link170">Link 170</a></li>
    <li><a href="#link171">Link 171</a></li>
    <li><a href="#link172">Link 172</a></li>
    <li><a href="#link173">Link 173</a></li>
    <li><a href="#link174">Link 174</a></li>
    <li><a href="#link175">Link 175</a></li>
    <li><a href="#link176">Link 176</a></li>
    <li><a href="#link177">Link 177</a></li>
    <li><a href="#link178">Link 178</a></li>
    <li><a href="#link179">Link 179</a></li>
    <li><a href="#link180">Link 180</a></li>
</ul>
<h2>Subheading 10</h2>
<p>This is a paragraph under Subheading 10. Wrapping up with links:</p>
<ul>
    <li><a href="#link181">Link 181</a></li>
    <li><a href="#link182">Link 182</a></li>
    <li><a href="#link183">Link 183</a></li>
    <li><a href="#link184">Link 184</a></li>
    <li><a href="#link185">Link 185</a></li>
    <li><a href="#link186">Link 186</a></li>
    <li><a href="#link187">Link 187</a></li>
    <li><a href="#link188">Link 188</a></li>
    <li><a href="#link189">Link 189</a></li>
    <li><a href="#link190">Link 190</a></li>
    <li><a href="#link191">Link 191</a></li>
    <li><a href="#link192">Link 192</a></li>
    <li><a href="#link193">Link 193</a></li>
    <li><a href="#link194">Link 194</a></li>
    <li><a href="#link195">Link 195</a></li>
    <li><a href="#link196">Link 196</a></li>
    <li><a href="#link197">Link 197</a></li>
    <li><a href="#link198">Link 198</a></li>
    <li><a href="#link199">Link 199</a></li>
    <li><a href="#link200">Link 200</a></li>
</ul>

Reproduction repository

No response

Relevant log output

Maximum execution time of 30 seconds exceeded
awcodes commented 1 week ago

This is going to be a result of something in your code or your server and not related to the plugin.

https://github.com/awcodes/filament-tiptap-editor/assets/3596800/7563746a-b858-4b4d-8ace-4fd8e635b6d5