Congratulations!

[Valid RSS] This is a valid RSS feed.

Recommendations

This feed is valid, but interoperability with the widest range of feed readers could be improved by implementing the following recommendations.

Source: http://www.perturb.org/rss.php

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <?xml-stylesheet type="text/css" href="/css/rss-browser.css" ?>
  3. <rss version="2.0">
  4. <channel>
  5. <title>Perturb.org - Scott's Geek Stuff</title>
  6. <link>http://www.perturb.org/</link>
  7. <description>Just Geek Stuff</description>
  8.  
  9. <item>
  10. <guid isPermaLink="true">http://www.perturb.org/display/entry/1439/</guid>
  11. <title>I was mentioned in the Perl v5.42 release notes</title>
  12. <link>http://www.perturb.org/display/entry/1439/</link>
  13. <description>&lt;p&gt;For the fourth year in a row I made it into the official Perl &lt;a href=&quot;https://metacpan.org/release/BOOK/perl-5.42.0/view/pod/perldelta.pod#Acknowledgements&quot;&gt;release notes&lt;/a&gt;. People get mentioned if they contribute code to the language. To be fair my contributions were documentation updates, but it&#039;s still pretty cool to get referenced in the &lt;em&gt;official&lt;/em&gt; release announcement that goes out to the entire world.&lt;/p&gt;</description>
  14. <pubDate>Thu, 09 Oct 2025 13:23:49 -0700</pubDate>
  15. </item>
  16. <item>
  17. <guid isPermaLink="true">http://www.perturb.org/display/entry/1438/</guid>
  18. <title>Linux: View all the lines in a file after a starting delimiter</title>
  19. <link>http://www.perturb.org/display/entry/1438/</link>
  20. <description>&lt;p&gt;I need to print all the lines in a text file after a certain time. You can do this pretty easily with a Perl one-liner:&lt;/p&gt;
  21. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;perl -nE &#039;if (/13:00/) { $found = 1; next } print if $found&#039; /var/log/messages&lt;/code&gt;&lt;/pre&gt;
  22. &lt;p&gt;The delimiter &lt;strong&gt;needs&lt;/strong&gt; to be in the file to trigger. If there was no line that matches &lt;code&gt;13:00&lt;/code&gt; &lt;em&gt;nothing&lt;/em&gt; will print.&lt;/p&gt;
  23. &lt;p&gt;&lt;strong&gt;Update:&lt;/strong&gt; This can also be accomplished with &lt;code&gt;awk&lt;/code&gt;:&lt;/p&gt;
  24. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;awk &#039;/13:00/ {found=1; next} found&#039; /var/log/messages&lt;/code&gt;&lt;/pre&gt;</description>
  25. <pubDate>Tue, 07 Oct 2025 14:50:31 -0700</pubDate>
  26. </item>
  27. <item>
  28. <guid isPermaLink="true">http://www.perturb.org/display/entry/1437/</guid>
  29. <title>Perl: Fetch data from a URL</title>
  30. <link>http://www.perturb.org/display/entry/1437/</link>
  31. <description>&lt;p&gt;I need a quick way to fetch JSON data from a URL. Using &lt;code&gt;HTTP::Tiny&lt;/code&gt; is the easiest way. You can call the function different ways depending on whether you &lt;strong&gt;only&lt;/strong&gt; want the body, or if you want the HTTP status code as well:&lt;/p&gt;
  32. &lt;pre&gt;&lt;code class=&quot;language-perl&quot;&gt;my $json = get_url(&quot;https://domain.com/stats.json&quot;);
  33. my ($html, $http_code) = get_url(&quot;https://domain.com/index.html&quot;);&lt;/code&gt;&lt;/pre&gt;
  34. &lt;pre&gt;&lt;code class=&quot;language-perl&quot;&gt;sub get_url {
  35.    my $url = shift();
  36.    my $http = HTTP::Tiny-&amp;gt;new(verify_SSL =&amp;gt; 1, timeout =&amp;gt; 5);
  37.    my $resp = $http-&amp;gt;get($url);
  38.    my $body   = $resp-&amp;gt;{content};
  39.    my $status = $resp-&amp;gt;{status};
  40.    my @ret = ($body, $status, $resp);
  41.    return @ret;
  42. }&lt;/code&gt;&lt;/pre&gt;</description>
  43. <pubDate>Fri, 03 Oct 2025 16:32:55 -0700</pubDate>
  44. </item>
  45. <item>
  46. <guid isPermaLink="true">http://www.perturb.org/display/entry/1436/</guid>
  47. <title>PHP: Return a random element from an array</title>
  48. <link>http://www.perturb.org/display/entry/1436/</link>
  49. <description>&lt;p&gt;Getting a random element from a PHP array is a multi-step process and I often forget the syntax. Here is a simple function that will return a random element from the provided array.&lt;/p&gt;
  50. &lt;pre&gt;&lt;code class=&quot;language-php&quot;&gt;function random_elem(array $arr) {
  51.    $key = array_rand($arr);
  52.    $ret = $arr[$key];
  53.    return $ret;
  54. }&lt;/code&gt;&lt;/pre&gt;</description>
  55. <pubDate>Mon, 08 Sep 2025 15:33:27 -0700</pubDate>
  56. </item>
  57. <item>
  58. <guid isPermaLink="true">http://www.perturb.org/display/entry/1435/</guid>
  59. <title>Mustache is a very simple and powerful templating language</title>
  60. <link>http://www.perturb.org/display/entry/1435/</link>
  61. <description>&lt;p&gt;I am late to the game learning about the &lt;a href=&quot;https://mustache.github.io/&quot;&gt;Mustache&lt;/a&gt; templating language. It is very mature, and has support for all of the languages I care about: &lt;a href=&quot;https://metacpan.org/pod/Template::Mustache&quot;&gt;Perl&lt;/a&gt;, &lt;a href=&quot;https://github.com/bobthecow/mustache.php&quot;&gt;PHP&lt;/a&gt;, and &lt;a href=&quot;https://github.com/janl/mustache.js&quot;&gt;Javascript&lt;/a&gt;. I am mainly focused on using it in Javascript as it is a great way to format raw data you get via JSON into something more human consumable like HTML.&lt;/p&gt;
  62. &lt;p&gt;&lt;a href=&quot;https://github.com/janl/mustache.js&quot;&gt;Mustache.js&lt;/a&gt; is &lt;em&gt;incredibly&lt;/em&gt; easy to implement and get started with. A single include loads the entire zero-dependency library. As of v4.2.0 the library is tiny, clocking in at only 25k. A big selling point is the ease of installation and use. You can be up and running with Mustache.js in less than 5 minutes.&lt;/p&gt;
  63. &lt;pre&gt;&lt;code class=&quot;language-html&quot;&gt;&amp;lt;script src=&quot;/js/mustache.min.js&quot;&amp;gt;&amp;lt;/script&amp;gt;&lt;/code&gt;&lt;/pre&gt;
  64. &lt;pre&gt;&lt;code class=&quot;language-javascript&quot;&gt;var data = { name: &quot;Jason&quot;, animal: &quot;Kitten&quot; };
  65. var str  = Mustache.render(&quot;&amp;lt;p&amp;gt;Hello {{name}}, I hear you like {{animal}}s&amp;lt;/p&amp;gt;&quot;, data);&lt;/code&gt;&lt;/pre&gt;
  66. &lt;p&gt;I liked it so much I wrote up a &lt;a href=&quot;https://www.perturb.org/code/mustache/&quot;&gt;Mustache sandbox&lt;/a&gt; to allow me to play around with the templating system live. The template syntax is a &lt;a href=&quot;https://mustache.github.io/mustache.5.html&quot;&gt;little archaic&lt;/a&gt;, but it is workable.&lt;/p&gt;
  67. &lt;p&gt;&lt;strong&gt;Note:&lt;/strong&gt; They even have &lt;a href=&quot;https://github.com/floatplane/ministache&quot;&gt;Arduino&lt;/a&gt; support, which I need to investigate.&lt;/p&gt;</description>
  68. <pubDate>Fri, 05 Sep 2025 11:17:35 -0700</pubDate>
  69. </item>
  70. <item>
  71. <guid isPermaLink="true">http://www.perturb.org/display/entry/1434/</guid>
  72. <title>PHP: Simplify sending JSON to a browser</title>
  73. <link>http://www.perturb.org/display/entry/1434/</link>
  74. <description>&lt;p&gt;I can never remember the correct MIME type for JSON so I wrote this wrapper function to simplify sending JSON to a browser.&lt;/p&gt;
  75. &lt;pre&gt;&lt;code class=&quot;language-PHP&quot;&gt;// Convert a PHP data structure to JSON and send it to the browser
  76. function json_output($obj) {
  77.    $output = json_encode($obj, JSON_INVALID_UTF8_SUBSTITUTE);
  78.    // http://tools.ietf.org/html/rfc4627
  79.    header(&#039;Content-type: application/json&#039;);
  80.    print $output;
  81.    exit;
  82. }&lt;/code&gt;&lt;/pre&gt;</description>
  83. <pubDate>Fri, 29 Aug 2025 11:19:44 -0700</pubDate>
  84. </item>
  85. <item>
  86. <guid isPermaLink="true">http://www.perturb.org/display/entry/1433/</guid>
  87. <title>Perl: Search and replace a string across your entire code base</title>
  88. <link>http://www.perturb.org/display/entry/1433/</link>
  89. <description>&lt;p&gt;I need to rename a function anywhere it is found in my code base. This requires going through every file and directory recursively, and checking each file. Using the Linux &lt;code&gt;find&lt;/code&gt; command we can find &lt;em&gt;all&lt;/em&gt; the files and then hand the search and replace off to Perl. Easy peasy.&lt;/p&gt;
  90. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;find codebase/ -type f -exec perl -pi -E &#039;s/foo/bar/g&#039; {} +&lt;/code&gt;&lt;/pre&gt;
  91. &lt;p&gt;or using &lt;code&gt;fd&lt;/code&gt; instead:&lt;/p&gt;
  92. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;fd . codebase/ --type f --exec-batch -pi -E &#039;s/foo/bar/g&#039; {}&lt;/code&gt;&lt;/pre&gt;</description>
  93. <pubDate>Wed, 20 Aug 2025 08:15:57 -0700</pubDate>
  94. </item>
  95. <item>
  96. <guid isPermaLink="true">http://www.perturb.org/display/entry/1432/</guid>
  97. <title>Linux: Testing for x86_64-v3</title>
  98. <link>http://www.perturb.org/display/entry/1432/</link>
  99. <description>&lt;p&gt;Modern Linux distributions are starting to require &lt;a href=&quot;https://en.wikipedia.org/wiki/X86-64#Microarchitecture_levels&quot;&gt;x86_64-v3&lt;/a&gt; capable CPUs to run. If you do not have a CPU modern enough you may not be able to install certain versions of Linux. To test if your hardware is capable you can run the following command:&lt;/p&gt;
  100. &lt;pre&gt;&lt;code&gt;/usr/lib64/ld-linux-x86-64.so.2 --help&lt;/code&gt;&lt;/pre&gt;
  101. &lt;p&gt;Basically any CPU made after 2015 will be fine.&lt;/p&gt;</description>
  102. <pubDate>Tue, 29 Jul 2025 16:29:18 -0700</pubDate>
  103. </item>
  104. <item>
  105. <guid isPermaLink="true">http://www.perturb.org/display/entry/1431/</guid>
  106. <title>PHP: Only start a session when it's needed</title>
  107. <link>http://www.perturb.org/display/entry/1431/</link>
  108. <description>&lt;p&gt;I use sessions on my sites for user authentication. Calling &lt;code&gt;session_start()&lt;/code&gt; initiates a session and allows me to check if the user is logged in or not. However, calling &lt;code&gt;session_start()&lt;/code&gt; creates a new session for &lt;strong&gt;every&lt;/strong&gt; hit on your site: bots, unauthenticated users, etc. This can lead to an &lt;em&gt;excess&lt;/em&gt; of session files on your filesystem.&lt;/p&gt;
  109. &lt;p&gt;A better way is to explicitly call &lt;code&gt;start_session()&lt;/code&gt; when your user logs in. On your other pages you can check if the user has the appropriate session cookie and start a session &lt;strong&gt;only&lt;/strong&gt; when it&#039;s needed.&lt;/p&gt;
  110. &lt;pre&gt;&lt;code class=&quot;language-PHP&quot;&gt;function start_session_if_exists() {
  111.    if (isset($_COOKIE[session_name()]) &amp;amp;&amp;amp; session_status() !== PHP_SESSION_ACTIVE) {
  112.        session_start();
  113.    }
  114. }&lt;/code&gt;&lt;/pre&gt;
  115. &lt;p&gt;This will avoid creating a session for every hit on your site.&lt;/p&gt;</description>
  116. <pubDate>Sat, 21 Jun 2025 11:29:02 -0700</pubDate>
  117. </item>
  118. <item>
  119. <guid isPermaLink="true">http://www.perturb.org/display/entry/1430/</guid>
  120. <title>CSS: Selecting text made easy</title>
  121. <link>http://www.perturb.org/display/entry/1430/</link>
  122. <description>&lt;p&gt;You can apply the &lt;a href=&quot;https://developer.mozilla.org/en-US/docs/Web/CSS/user-select&quot;&gt;user-select&lt;/a&gt; CSS property to an element to control how it handles selecting text for copy and paste. This allows you to limit selecting text, or make it automatic. If you use the &lt;code&gt;all&lt;/code&gt; property, anytime a user clicks on that element the text is automatically selected. This can be useful for keys or codes where the user is &lt;strong&gt;expected&lt;/strong&gt; to copy and paste the text.&lt;/p&gt;
  123. &lt;pre&gt;&lt;code class=&quot;language-css&quot;&gt;.click_select { user-select: all; }&lt;/code&gt;&lt;/pre&gt;
  124. &lt;p&gt;Example:&lt;/p&gt;
  125. &lt;style&gt;
  126.    .click_select {
  127.        user-select: all;
  128.    }
  129.    .test_button {
  130.        border: 1px solid black;
  131.        padding: 12px;
  132.        border-radius: 4px;
  133.        background: darkblue;
  134.    }
  135. &lt;/style&gt;
  136. &lt;p&gt;&lt;span class=&quot;click_select test_button&quot;&gt;Click me!&lt;/span&gt;&lt;/p&gt;</description>
  137. <pubDate>Tue, 17 Jun 2025 09:58:19 -0700</pubDate>
  138. </item>
  139. <item>
  140. <guid isPermaLink="true">http://www.perturb.org/display/entry/1429/</guid>
  141. <title>Linux: Find all the text files in a directory</title>
  142. <link>http://www.perturb.org/display/entry/1429/</link>
  143. <description>&lt;p&gt;I need to find all the &lt;em&gt;text&lt;/em&gt; files in a given directory for potential clean up. There is not a super easy way to find only text files, but I came up with a hacky solution:&lt;/p&gt;
  144. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;# Using `fd` (new hotness)
  145. fd . /tmp/ --exec file {} + | grep -P &quot;:.*text&quot; | cut -d: -f1
  146. # Using old school `find` (old and busted)
  147. find /tmp/ -exec file {} + | grep -P &quot;:.*text&quot; | cut -d: -f1&lt;/code&gt;&lt;/pre&gt;
  148. &lt;p&gt;These rely on the &lt;code&gt;file&lt;/code&gt; command to determine what the filetype is.&lt;/p&gt;</description>
  149. <pubDate>Fri, 06 Jun 2025 18:30:02 -0700</pubDate>
  150. </item>
  151. <item>
  152. <guid isPermaLink="true">http://www.perturb.org/display/entry/1428/</guid>
  153. <title>Javascript: Copy string to clipboard</title>
  154. <link>http://www.perturb.org/display/entry/1428/</link>
  155. <description>&lt;p&gt;I needed a modern way to copy a string to the clipboard in JavaScript. &lt;a href=&quot;https://claude.ai&quot;&gt;Claude.ai&lt;/a&gt; helped me come up with this:&lt;/p&gt;
  156. &lt;pre&gt;&lt;code class=&quot;language-javascript&quot;&gt;// With async/await
  157. async function copyToClipboard(text) {
  158.    try {
  159.        await navigator.clipboard.writeText(text);
  160.        console.log(&#039;Copied to clipboard&#039;);
  161.    } catch (err) {
  162.        console.error(&#039;Failed to copy: &#039;, err);
  163.    }
  164. }&lt;/code&gt;&lt;/pre&gt;
  165. &lt;p&gt;Then you simply call it with a string&lt;/p&gt;
  166. &lt;pre&gt;&lt;code class=&quot;language-javascript&quot;&gt;copyToClipboard(&quot;Hello world&quot;);&lt;/code&gt;&lt;/pre&gt;</description>
  167. <pubDate>Tue, 03 Jun 2025 15:25:29 -0700</pubDate>
  168. </item>
  169. <item>
  170. <guid isPermaLink="true">http://www.perturb.org/display/entry/1427/</guid>
  171. <title>Rocky 10 package versions</title>
  172. <link>http://www.perturb.org/display/entry/1427/</link>
  173. <description>&lt;p&gt;RedHat Enterprise Linux/Rocky 10 has these versions of packages:&lt;/p&gt;
  174. &lt;table&gt;
  175. &lt;thead&gt;
  176. &lt;tr&gt;
  177. &lt;th&gt;Package&lt;/th&gt;
  178. &lt;th&gt;Version&lt;/th&gt;
  179. &lt;/tr&gt;
  180. &lt;/thead&gt;
  181. &lt;tbody&gt;
  182. &lt;tr&gt;
  183. &lt;td&gt;Apache&lt;/td&gt;
  184. &lt;td&gt;2.4.63&lt;/td&gt;
  185. &lt;/tr&gt;
  186. &lt;tr&gt;
  187. &lt;td&gt;GCC&lt;/td&gt;
  188. &lt;td&gt;14.2.1&lt;/td&gt;
  189. &lt;/tr&gt;
  190. &lt;tr&gt;
  191. &lt;td&gt;Git&lt;/td&gt;
  192. &lt;td&gt;2.47.1&lt;/td&gt;
  193. &lt;/tr&gt;
  194. &lt;tr&gt;
  195. &lt;td&gt;Kernel&lt;/td&gt;
  196. &lt;td&gt;6.12&lt;/td&gt;
  197. &lt;/tr&gt;
  198. &lt;tr&gt;
  199. &lt;td&gt;MariaDB&lt;/td&gt;
  200. &lt;td&gt;10.11.11&lt;/td&gt;
  201. &lt;/tr&gt;
  202. &lt;tr&gt;
  203. &lt;td&gt;OpenSSH&lt;/td&gt;
  204. &lt;td&gt;9.9p1&lt;/td&gt;
  205. &lt;/tr&gt;
  206. &lt;tr&gt;
  207. &lt;td&gt;Perl&lt;/td&gt;
  208. &lt;td&gt;5.40.2&lt;/td&gt;
  209. &lt;/tr&gt;
  210. &lt;tr&gt;
  211. &lt;td&gt;PHP&lt;/td&gt;
  212. &lt;td&gt;8.3.19&lt;/td&gt;
  213. &lt;/tr&gt;
  214. &lt;tr&gt;
  215. &lt;td&gt;Vim&lt;/td&gt;
  216. &lt;td&gt;9.1.83&lt;/td&gt;
  217. &lt;/tr&gt;
  218. &lt;/tbody&gt;
  219. &lt;/table&gt;</description>
  220. <pubDate>Mon, 02 Jun 2025 15:10:07 -0700</pubDate>
  221. </item>
  222. <item>
  223. <guid isPermaLink="true">http://www.perturb.org/display/entry/1426/</guid>
  224. <title>Javascript: Returning data from an AJAX call</title>
  225. <link>http://www.perturb.org/display/entry/1426/</link>
  226. <description>&lt;p&gt;Javascript is by it&#039;s nature asynchronous, which makes returning data from an AJAX call complicated. Modern Javascript uses the concept of a &quot;&lt;a href=&quot;https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise&quot;&gt;promise&lt;/a&gt;&quot; to allow you to run code after an asynchronous call competes. This is similar to using a callback function, but it reads cleaner. JQuery implements this type of call with the &lt;a href=&quot;https://api.jquery.com/deferred.then/&quot;&gt;&lt;code&gt;then()&lt;/code&gt;&lt;/a&gt; function. A simple example is as follows:&lt;/p&gt;
  227. &lt;pre&gt;&lt;code class=&quot;language-javascript&quot;&gt;function getData() {
  228.    return $.ajax({
  229.        url: &#039;/api/data&#039;
  230.    });
  231. }
  232. // Usage
  233. getData().then(function(data) {
  234.    console.log(data);
  235. });&lt;/code&gt;&lt;/pre&gt;</description>
  236. <pubDate>Wed, 28 May 2025 19:59:48 -0700</pubDate>
  237. </item>
  238. <item>
  239. <guid isPermaLink="true">http://www.perturb.org/display/entry/1425/</guid>
  240. <title>PHP: Generate secure password hashes from the CLI</title>
  241. <link>http://www.perturb.org/display/entry/1425/</link>
  242. <description>&lt;p&gt;The &lt;code&gt;password_hash()&lt;/code&gt; function in PHP is excellent for storing passwords securely. In order to generate password to store in a database or config file I like to generate passwords from the CLI. This has the risk of storing the password in your bash history. This command prompts you for the password on the fly and protects your history.&lt;/p&gt;
  243. &lt;pre&gt;&lt;code class=&quot;language-bash&quot;&gt;php -r &#039;echo &quot;Password: &quot;; $pwd = trim(fgets(STDIN)); echo password_hash($pwd, PASSWORD_DEFAULT) . &quot;\n&quot;;&#039;&lt;/code&gt;&lt;/pre&gt;</description>
  244. <pubDate>Sat, 24 May 2025 20:13:35 -0700</pubDate>
  245. </item>
  246. </channel>
  247. </rss>
  248.  

If you would like to create a banner that links to this page (i.e. this validation result), do the following:

  1. Download the "valid RSS" banner.

  2. Upload the image to your own server. (This step is important. Please do not link directly to the image on this server.)

  3. Add this HTML to your page (change the image src attribute if necessary):

If you would like to create a text link instead, here is the URL you can use:

http://www.feedvalidator.org/check.cgi?url=http%3A//www.perturb.org/rss.php

Copyright © 2002-9 Sam Ruby, Mark Pilgrim, Joseph Walton, and Phil Ringnalda