 &amp; SBIT?</h1><p class="page-description"></p><table class="properties"><tbody><tr class="property-row property-row-created_by"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedBy"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 10.4229C6.05176 10.4229 4.54785 11.1133 3.83008 11.9131C2.90039 10.9082 2.33301 9.55469 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 9.55469 13.1064 10.9082 12.1699 11.9131C11.4521 11.1133 9.94824 10.4229 8 10.4229ZM8 9.30176C9.32617 9.30859 10.3516 8.18066 10.3516 6.71094C10.3516 5.33008 9.31934 4.18164 8 4.18164C6.6875 4.18164 5.6416 5.33008 5.64844 6.71094C5.65527 8.18066 6.68066 9.28809 8 9.30176Z"></path></svg></span>Created by</th><td><span class="user"><img src="rwxrwxrwx%20Also,%20SUID,%20SGID%20&amp;%20SBIT%20bf7c7b4b757941978684c0c11b554e81/IMG_2295.jpg" class="icon user-icon"/>JiaLin Huang</span></td></tr><tr class="property-row property-row-last_edited_time"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesCreatedAt"><path d="M8 15.126C11.8623 15.126 15.0615 11.9336 15.0615 8.06445C15.0615 4.20215 11.8623 1.00293 7.99316 1.00293C4.13086 1.00293 0.938477 4.20215 0.938477 8.06445C0.938477 11.9336 4.1377 15.126 8 15.126ZM8 13.7383C4.85547 13.7383 2.33301 11.209 2.33301 8.06445C2.33301 4.91992 4.84863 2.39746 7.99316 2.39746C11.1377 2.39746 13.6738 4.91992 13.6738 8.06445C13.6738 11.209 11.1445 13.7383 8 13.7383ZM4.54102 8.91211H7.99316C8.30078 8.91211 8.54004 8.67285 8.54004 8.37207V3.8877C8.54004 3.58691 8.30078 3.34766 7.99316 3.34766C7.69238 3.34766 7.45312 3.58691 7.45312 3.8877V7.83203H4.54102C4.2334 7.83203 4.00098 8.06445 4.00098 8.37207C4.00098 8.67285 4.2334 8.91211 4.54102 8.91211Z"></path></svg></span>Last edited</th><td><time>@2024年9月26日 19:15</time></td></tr><tr class="property-row property-row-multi_select"><th><span class="icon property-icon"><svg role="graphics-symbol" viewBox="0 0 16 16" style="width:14px;height:14px;display:block;fill:rgba(55, 53, 47, 0.45);flex-shrink:0" class="typesMultipleSelect"><path d="M1.91602 4.83789C2.44238 4.83789 2.87305 4.40723 2.87305 3.87402C2.87305 3.34766 2.44238 2.91699 1.91602 2.91699C1.38281 2.91699 0.952148 3.34766 0.952148 3.87402C0.952148 4.40723 1.38281 4.83789 1.91602 4.83789ZM5.1084 4.52344H14.3984C14.7607 4.52344 15.0479 4.23633 15.0479 3.87402C15.0479 3.51172 14.7607 3.22461 14.3984 3.22461H5.1084C4.74609 3.22461 4.45898 3.51172 4.45898 3.87402C4.45898 4.23633 4.74609 4.52344 5.1084 4.52344ZM1.91602 9.03516C2.44238 9.03516 2.87305 8.60449 2.87305 8.07129C2.87305 7.54492 2.44238 7.11426 1.91602 7.11426C1.38281 7.11426 0.952148 7.54492 0.952148 8.07129C0.952148 8.60449 1.38281 9.03516 1.91602 9.03516ZM5.1084 8.7207H14.3984C14.7607 8.7207 15.0479 8.43359 15.0479 8.07129C15.0479 7.70898 14.7607 7.42188 14.3984 7.42188H5.1084C4.74609 7.42188 4.45898 7.70898 4.45898 8.07129C4.45898 8.43359 4.74609 8.7207 5.1084 8.7207ZM1.91602 13.2324C2.44238 13.2324 2.87305 12.8018 2.87305 12.2686C2.87305 11.7422 2.44238 11.3115 1.91602 11.3115C1.38281 11.3115 0.952148 11.7422 0.952148 12.2686C0.952148 12.8018 1.38281 13.2324 1.91602 13.2324ZM5.1084 12.918H14.3984C14.7607 12.918 15.0479 12.6309 15.0479 12.2686C15.0479 11.9062 14.7607 11.6191 14.3984 11.6191H5.1084C4.74609 11.6191 4.45898 11.9062 4.45898 12.2686C4.45898 12.6309 4.74609 12.918 5.1084 12.918Z"></path></svg></span>Tags</th><td></td></tr></tbody></table></header><div class="page-body"><p class="">
</p><h1 class="">As You may know the default column</h1><p class="">You already know about rwx rwx rwx, which represents owner, group, and others respectively. Each group has its own rwx, and if you&#x27;re the owner, you look at the first rwx group.</p><p class="">
</p><p class="">Using <code>ls -l</code>, you&#x27;ll see these symbols before the file name:</p><ul class="bulleted-list"><li style="list-style-type:disc"><strong>Directories typically have x</strong>, which means they can be opened</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">Locally created files usually don&#x27;t have <code>@</code></li></ul><ul class="bulleted-list"><li style="list-style-type:disc"><mark class="highlight-red"><strong>@ indicates extended attributes.</strong></mark> These are additional metadata associated with the file or directory, beyond the standard Unix permissions and ownership information<ul class="bulleted-list"><li style="list-style-type:circle">Think about <span style="border-bottom:0.05em solid">index key in db</span></li></ul><ul class="bulleted-list"><li style="list-style-type:circle">A screenshot image, camera model?</li></ul><ul class="bulleted-list"><li style="list-style-type:circle">Usually, macOS files or datasets have com.apple.macl, which is a more nuanced permission management compared to traditional rwx, but that&#x27;s managed by the system. We humans just manage rwx.</li></ul></li></ul><p class="">
</p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash"> $  ls -l
total 6832
-rw-r--r--@  1 jialinhuang  staff    78529 25 Sep 14:12 Screenshot 2024-09-25 at 2.12.56 PM.png
-rw-r--r--@  1 jialinhuang  staff        5 25 Sep 16:57 localFile.txt
drwxr-xr-x@ 10 jialinhuang  staff      320 25 Mar  2024 github-project
drwxr-xr-x@  6 jialinhuang  staff      192 20 Sep 10:03 github-project-2
drwxr-xr-x   9 jialinhuang  staff      288 20 Sep 10:16 localDirectory
drwxr-xr-x@ 23 jialinhuang  staff      736 24 Sep 14:01 abcdirectory
-rw-rw-r--@  1 jialinhuang  staff   465188 19 Sep 13:39 random.pdf</code></pre><table class="simple-table"><tbody><tr><td class=""></td><td class="">-, d, l, b, c, p, s</td><td class="" style="width:48px">user</td><td class="" style="width:61px">group</td><td class="" style="width:57.994789123535156px">others</td><td class="">@</td></tr><tr><td class="">default</td><td class=""><code>-</code> for file<br/><br/><code>d</code> for directory<br/>…<br/></td><td class="" style="width:48px">rwx</td><td class="" style="width:61px">rwx</td><td class="" style="width:57.994789123535156px">rwx</td><td class="">Extended Attributes</td></tr><tr><td class="">if <strong>SUID</strong> is set</td><td class=""></td><td class="" style="width:48px">rw<mark class="highlight-red"><strong>s</strong></mark></td><td class="" style="width:61px"></td><td class="" style="width:57.994789123535156px"></td><td class=""></td></tr><tr><td class="">if <strong>SGID</strong> is set</td><td class=""></td><td class="" style="width:48px"></td><td class="" style="width:61px">rw<mark class="highlight-red"><strong>s</strong></mark></td><td class="" style="width:57.994789123535156px"></td><td class=""></td></tr><tr><td class="">if <strong>Sticky</strong> is set</td><td class=""></td><td class="" style="width:48px"></td><td class="" style="width:61px"></td><td class="" style="width:57.994789123535156px">rw<mark class="highlight-red"><strong>t</strong></mark></td><td class=""></td></tr></tbody></table><h1 class="">When a device got so many users</h1><p class="">While simple rwx permission management can control basic access to files and directories, <mark class="highlight-red"><strong>it has some shortcomings in multi-user environments, which led to the introduction of SUID, SGID, and Sticky Bit.</strong></mark></p><p class="">For instance, operating on the same resource, but you belong to different groups and need to adjust permissions manually.</p><p class=""><mark class="highlight-blue"><strong>sgid comes up.</strong></mark></p><p class="">
</p><p class="">Operating on the same resource, but everyone can freely change things inside, deleting others&#x27; efforts?</p><p class=""><mark class="highlight-blue"><strong>sticky comes up.</strong></mark></p><p class="">
</p><p class="">For resources owned by a certain user, in practice, everyone wants to be able to operate on it, but is limited because they&#x27;re not the owner.</p><p class=""><mark class="highlight-blue"><strong>suid comes up.</strong></mark></p><p class="">
</p><h1 class="">SUID (Set User ID)</h1><p class="">User means current user, means the owner.<br/>This s is located in the owner&#x27;s rwx, looking like this:<br/></p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">-rwsr-xr-x</code></pre><p class="">When an item has the user group&#x27;s execute set to s, it means even if you&#x27;re not the owner, you can still execute it.<br/><br/><mark class="highlight-red">You&#x27;re not the owner, but you can fake it.</mark></p><p class="">One you&#x27;ve definitely used before, when using VM or Container to set permissions or passwords, using <code>su -</code> to expand your current permissions to root, but you&#x27;re still not root.</p><p class="">
</p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">chmod u+s &lt;file name&gt;</code></pre><h1 class=""><strong>SGID (Set Group ID)</strong></h1><p class="">This &#x27;s&#x27; is located in the group&#x27;s rwx section, as shown above.</p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">-rwxr-sr-x</code></pre><p class="">
</p><ul class="bulleted-list"><li style="list-style-type:disc"><mark class="highlight-red"><strong>For files</strong></mark>: When set on an executable file, it allows the file to be executed with the permissions of the file&#x27;s group.<p class="">You&#x27;re belonging to group A, you need to change something that is from group B. You can still execute group B stuff, but remember you&#x27;re just faking like you&#x27;re in group B.</p></li></ul><ul class="bulleted-list"><li style="list-style-type:disc"><mark class="highlight-red"><strong>For directories</strong></mark>: Files created in an SGID directory inherit the group ownership of the directory, rather than the primary group of the user creating the file.<p class="">You can still execute group B&#x27;s directory, but everything you change just doesn&#x27;t belong to your group A.</p></li></ul><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">chmod g+s [filename || directory]</code></pre><h1 class="">Sticky</h1><p class="">In a place where everyone can operate, setting &#x27;t&#x27; specifically means you&#x27;re limited to adding or removing files that you own. It can apply to file or directory, but <mark class="highlight-red"><strong>you can only change your own part that belongs to you.</strong></mark></p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">chmod +t [directory]</code></pre><p class="">
</p><p class="">
</p><p class="">
</p><h1 class="">Setting Permissions: chmod</h1><h3 class="">Using Symbols</h3><ol type="1" class="numbered-list" start="1"><li>Basic usage<p class="">a: all, u: user (owner), g: group, o: others</p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">chmod &lt;a|u|g|o&gt;...+&lt;r|w|x&gt;...

# Allow read for all
chmod a+r &lt;file&gt;
# Allow full access for all
chmod a+rwx &lt;file&gt;
# Allow write for group and others
chmod go+w &lt;file&gt;</code></pre></li></ol><ol type="1" class="numbered-list" start="2"><li>Directory execute permission: The &#x27;x&#x27; for directories means: allow to open/access<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">$  chmod u-x normal-dir
$  cd normal-dir
cd: permission denied: normal-dir

# add back the right to execute
$  chmod u+x normal-dir</code></pre></li></ol><ol type="1" class="numbered-list" start="3"><li>Special permissions (SUID, SGID, Sticky):<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash"># Set SUID
chmod u+s &lt;file&gt;
# Set SGID
chmod g+s &lt;file&gt;
# Set Sticky bit
chmod +t &lt;directory&gt;
# Note: u+t and g+t have no effect (no error, but no change)

# no target group &quot;s&quot;
chmod +s test
# Equivalent to
chmod u+s test
chmod g+s test</code></pre></li></ol><p class="">
</p><h3 class="">Using Numbers</h3><ol type="1" class="numbered-list" start="1"><li>Special permission numbers:<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">SUID SGID Sticky Binary Octal Description
-    -    -      000    0     No special permissions
-    -    t      001    1     Sticky bit only
-    s    -      010    2     SGID only
-    s    t      011    3     SGID and Sticky
s    -    -      100    4     SUID only
s    -    t      101    5     SUID and Sticky
s    s    -      110    6     SUID and SGID
s    s    t      111    7     All special permissions


chmod 4755 file  # Set SUID numerically
chmod 2755 directory  # Set SGID numerically
chmod 1755 directory  # Set sticky bit numerically</code></pre></li></ol><ol type="1" class="numbered-list" start="2"><li><mark class="highlight-red">SGID example:</mark><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash"># Set SGID, if group has execute permission (?????x???), use &#x27;s&#x27;, else &#x27;S&#x27;
# On macOS, it automatically checks for &#x27;x&#x27;, lowercase &#x27;s&#x27; works even without &#x27;x&#x27;
chmod g+s test
# Equivalent to
chmod 2644 test.txt</code></pre></li></ol><ol type="1" class="numbered-list" start="3"><li>Numeric vs Symbolic notation: When using numbers, consider the entire rwxrwxrwx set. For example:<script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash"># Allow execute for all (symbolic)
chmod a+x &lt;file&gt;

# Equivalent to
chmod u+x &lt;file&gt;
chmod g+x &lt;file&gt;
chmod o+x &lt;file&gt;

# NOT Equivalent to
# But numerically, this removes existing r and w permissions
chmod 111 &lt;file&gt;</code></pre></li></ol><p class="">
</p><h3 class="">More examples</h3><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash"># Remove all permissions
chmod 000 &lt;file&gt;
# Results in: ---------

# Set full permissions for owner, none for others
chmod 700 &lt;file&gt;
# Results in: rwx------

# Remove execute for others (assuming starting from 755)
chmod o-x &lt;file&gt;
# Results in: rwxr-xr--

# Remove execute for user and others
chmod uo-x &lt;file&gt;
# Results in: rw-r-xr--

# Change owner (requires sudo)
sudo chown root &lt;file&gt;</code></pre><p class="">
</p><p class="">
</p><p class="">
</p><h1 class="">Uppercase S &amp; T: What Do They Mean?</h1><p class=""><mark class="highlight-red"><strong>The uppercase S and T in file permissions indicate that the SUID, SGID, or sticky bit is set</strong></mark>, but the corresponding execute permission is not present. This distinction is important to understand:</p><ul class="bulleted-list"><li style="list-style-type:disc">If the rwx permissions are set to 0 and you grant special permissions (SUID, SGID, or sticky bit), you&#x27;ll see uppercase S or T in the output.</li></ul><ul class="bulleted-list"><li style="list-style-type:disc">The uppercase S and T merely reflect the state of special permissions when execute rights are absent. <mark class="highlight-red"><strong>The actual ability to access the file is primarily determined by the rwx permissions.</strong></mark></li></ul><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">chmod 0 cat.txt
# Remove all permissions

chmod 7000 cat.txt
# Set SUID, SGID, and sticky bit without any rwx permissions
# Results in:
# ---S--S--T   1 jialinhuang  staff        5 25 Sep 16:57 cat.txt</code></pre><p class="">
</p><p class="">
</p><h1 class="">What if we <code>chmod 0 /bin/chmod</code>?</h1><p class="">😨</p><p class="">Don&#x27;t panic!</p><p class="">While this command removes all permissions from the <code>chmod</code> command itself, rendering it unusable for regular users, there&#x27;s still a solution:</p><p class="">The root user, as a superuser, can transcend normal permission restrictions. You can restore the situation using root privileges.</p><p class="">
</p><script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js" integrity="sha512-7Z9J3l1+EYfeaPKcGXu3MS/7T+w19WtKQY/n+xzmw4hZhJ9tyYmcUS+4QqAlzhicE5LAfMQSF3iFTK9bQdTxXg==" crossorigin="anonymous" referrerPolicy="no-referrer"></script><link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism.min.css" integrity="sha512-tN7Ec6zAFaVSG3TpNAKtk4DOHNpSwKHxxrsiw4GHKESGPs5njn/0sMCUMl2svV4wo4BK/rCP7juYz+zx+l6oeQ==" crossorigin="anonymous" referrerPolicy="no-referrer"/><pre class="code"><code class="language-Bash">$  chmod 0 cat.txt
$  cat cat.txt
cat: cat.txt: Permission denied

$  sudo cat cat.txt
Password:
ahha</code></pre><p class="">
</p><p class="">
</p><p class="">
</p><p class=""><a href="https://www.cis.rit.edu/class/simg211/unixintro/Access_Permissions.html">https://www.cis.rit.edu/class/simg211/unixintro/Access_Permissions.html</a></p><p class=""><a href="https://dywang.csie.cyut.edu.tw/dywang/linuxsecurity/node39.html">https://dywang.csie.cyut.edu.tw/dywang/linuxsecurity/node39.html</a></p><p class=""><a href="https://www.quora.com/What-is-the-result-of-chmod-000-which-chmod-What-exactly-are-the-after-effects">https://www.quora.com/What-is-the-result-of-chmod-000-which-chmod-What-exactly-are-the-after-effects</a></p></div></article><span class="sans" style="font-size:14px;padding-top:2em"></span></body>
~/
about
posts
frontbacknetworkoscloud
readings
css
bookmarks
archives
© 2024 jialin00.com Original content since 2022
And maybe its just slow involvement at first, but try to sort of creep your career in that direction, because if youre not being challenged, if youre not a little bit scared all the time, just a little bit, then youre not gonna improve. - The Myth of the Genius Programmer