1,234
edits
Changes
no edit summary
{{Admon/caution|DO NOT USE THIS VERSION OF THE LAB. This page will no longer be updated.|'''New version here:''' https://seneca-ictoer.github.io/ULI101/A-Tutorials/tutorial4<br />'''Andrew's students please go here:''' http://wiki.littlesvr.ca/wiki/OPS145_Lab_4}}
=Data Representation / Numbering Conversion / File Permissions=
===Main Objectives of this Practice Tutorial===
:* Understand the importance of how digital computers store data (i.e. data representation)
:* Understand the purpose of Define '''decimal''', '''binary''', '''octal''' and '''hexadecimal''' numbers
:* Perform various Manually perform '''numbering conversions''' between the '''decimal''', '''binary''', '''octal''' and '''hexadecimal''' numbering systems<br>by hand (<u>without</u> the use of a computer or calculator)
:* Identify Explain the purpose of '''which numbering system conversion method to usefile permissions''' when required to perform a numbering conversion
:* Understand directory and regular file Explain how permissions work differently for '''directories''' as opposed for '''permissionsregular files'''
:* Learn how to '''set''' directory and regular Change file '''permissions''' with the '''chmod''' command (both ''symbolic '' and octal ''absolute'' methods)
:* Learn how to use Use the '''umask''' command to have automatically assign permissions for '''newly created directories ''' and files automatically set upon their '''creationregular files'''<br><br>
===Tutorial Reference Material===
|- valign="top" style="padding-left:15px;"
|colspan="1" width="22%" |Course Notes'''Slides:'''<ul><li>Week 4 Lecture 1 Notes:<br>[https://ictwiki.cdot.senecacollege.ca/~murrayuli101/slides/ULI101-4.1.pdf PDF] | [https://wiki.saulcdot.senecacollege.ca/uli101/slides/ULI101-Week44.1.pptx PPTX]</li><li>Week 4 Lecture 2 Notes:<br> [https://wiki.cdot.senecacollege.ca/uli101/slides/ULI101-4.2.pdf PDF] | [https://ictwiki.cdot.senecacollege.ca/~murray.saululi101/uli101slides/ULI101-Week44.2.pptx PPTX]<br></li></ul>
| style="padding-left:15px;" | '''Data RepresentationDefinitions:'''* [https://home.adelphi.edu/~siegfried/cs170/170l1.pdf DefinitionsData Representation]<br>* [https://en.wikipedia.org/wiki/Decimal DecimalNumbers] , * [https://en.wikipedia.org/wiki/Binary_number BinaryNumbers] , * [https://en.wikipedia.org/wiki/Octal OctalNumbers] , * [https://en.wikipedia.org/wiki/Hexadecimal HexadecimalNumbers] Numbers<br><br>
| colspan="1" style="padding-left:15px;" width="30%"|File Permissions'''Instructional Videos:'''* [httphttps://man7www.youtube.orgcom/linux/man-pages/man1/chmod.1.html chmodwatch?v=4nGgqLIKU9U Numbering Conversions]<br>* [httphttps://man7www.youtube.orgcom/linux/man-pages/man1/umask.1p.html umaskwatch?v=SdgiYoOi0CY File Permissions]<br><br>|}
===Data Representation===[[Image:binary-number1.png|}right|200px|https://creativecommons.org/licenses/by-sa/3.0/ cc]]Digital computers are '''electronic devices''' that contain a series of '''circuits''' and voltage levels that can store / represent data.
''Reasons to Understand IT Professionals that Use Data Representation:''
* ''C ProgrammingNetwork Specialists'': Building Large Networks via Sub-netting* ''Programmers:'' Sending information over networks, files* ''Web DevelopmentDevelopers:'' Setting color codes for webpage background or text * ''Allowing or Limiting Unix / Linux File AccessSystem Administrators:'' Setting ''permissions'' for files and directories <br>
===Numbering Conversion Methods===
<br><br>
==== <u>Method 2: Decimal / to Binary </ Octal / Hexadecimal Numbering Systemsu> ====
[[Image:decimal-numberto-1bin.png|thumb|right|200px275px|The Performing a '''decimal''' numbering system to '''binary''' conversion.]]When converting '''decimal''' numbers to '''binary''' numbers, perform the following steps:<br><br># Write down the '''decimal number''' to be converted.# On the ''right-side'', write the number '''1''' and moving '''leftwards''', keep <u>doubling</u> the numbers until that number is '''greater than'Decimal Numbers''the decimal number to be converted (refer to the diagram on the right).<br># Starting on the left-side of those doubled numbers, compare that number with the decimal number. If that number if less than or equal to the decimal number, then write a '''1''' below and subtract that number from the decimal number to get a remainder. If the number is greater than decimal number (or remainder), then write a '''0''' below.<br><br># Repeat '''step #3''' (moving rightwards and comparing the number with the decimal's remainder)<br><br>'''NOTE:''' If you are converting to '''8-bit''', '''32-bit''', etc., add '''leading zeros''' if necessary.<br><br>
<br><br>
===Numbering Conversion MethodsFile Permissions=== [[Image:listing-file-directory.png|thumb|right|400px|Detailed directory listing showing permissions for a '''directory'''<br>and a '''regular file'''.]]Since Unix / Linux operating file systems allow for '''multiple user accounts'''<br>it is essential to have a system to '''share''' or '''limit''' access to directories and files contained within the file system.
The permissions of '''newly-created''' directories and regular files are automatically assigned<br>via a '''user mask''' (we will discuss this shortly). In order to change permissions for<br>directories and regular files, you would use the '''chmod''' command.
'''<span style==== "font-style:italic">Symbolic Method 4: Hexadecimal to Binary </ Binary to Hexadecimal ====span>'''
Since 1 octal digit represents 3 binary digits, one octal digit can represent the <brspan style="font-family:courier;font-weight:bold;">rwx<br/span>permission granted or NOT granted. The permissions '''rwx''' are be in the form of 3 binary digits (1 represents the permission granted and 0 represents the permission NOT granted).
<table align===File Permissions==="right"><tr><td>[[Image:umask-directory.png|thumb|right|150px|Setting '''umask''' for newly-created '''directories'''.]]</td><td>[[Image:umask-file.png|thumb|right|150px|Setting '''umask''' for newly-created '''regular files''']]</td></tr></table>The '''umask''' command is used to set the permissions of newly-created directories and regular files.
Issuing the '''umask''' command without arguments will display the current umask value.
Refer to the diagrams on the right-side to set the umask value for directories and regular files.
Setting the umask value (for example umask 022) only takes effect for the current shell session unless the umask command is contained in a start-up file<br>(e.g. '''.profile''', '''.bash_profile''', or '''.bashrc''').
<br><br>
=INVESTIGATION 1: NUMBERING CONVERSIONS=
<span style="color:red;">'''ATTENTION''': This online tutorial will be required to be completed by '''Friday in week 5 by midnight''' to obtain a grade of '''2%''' towards this course</span><br><br>
=INVESTIGATION 2: FILE PERMISSIONS=
[[Image:file-permission-practice-1.png|right|250px|thumb|]]
In this investigation, you will get experience using the '''chmod''' command to '''change permissions'''<br>for <u> existing</u> files and the using '''umask''' command to automatically set permissions<br>for <u>newly-created</u> files.
'''Perform the Following Steps:'''
# '''Login''' to your matrix account and issue a command to '''confirm''' you are located in your '''home''' directory.<br><br># Issue a single Linux command to create the following directory structure displayed in the diagram to the right.<br><br>'''NOTE:''' You will now run a shell script to confirm that you properly created that directory structure<br>in your ''Matrix'' account.<br><br># Issue the following Linux command to run a checking script:<br><span style="color:blue;font-weight:bold;font-family:courier;">~uli101/week4-check-1</span><br><br># If you encounter errors, make corrections and '''re-run''' the checking script until you<br>receive a congratulations message, then you can proceed.<br><br>[[Image:file-permission-practice-2.png|right|450px|thumb|]]# Issue Linux commands to create '''<u>empty</u> files''' for each of those newly created '''directories''' as shown in diagram to the right:<br><br>'''NOTE:''' You will now run another shell script to confirm that you properly created those empty files within those specified directories.<br><br># Issue the following Linux command to run a checking script:<br><span style="color:blue;font-weight:bold;font-family:courier;">~uli101/week4-check-2</span><br><br># If you encounter errors, make corrections and '''re-run''' the checking script until you<br>receive a congratulations message, then continue the remaining steps.<br><br>Let's get practice '''viewing permissions''', '''changing permissions''', and <u>automatically</u> '''setting permissions for newly created files'''.<br><br># Issue the following Linux commands:<br><span style="color:blue;font-weight:bold;font-family:courier;">ls -ld ~/documents ~/clients ~/vendors<br>ls -lR ~/documents ~/clients ~/vendors</span><br><br>'''NOTE:''' You should see permissions already set for those newly created directories and regular files.<br>What do these permissions mean for '''same group member''' and '''other group member''' access to those directory and regular files?<br><br># Let's limit access to the '''clients''' and '''vendors''' directories to only yourself and same group members.<br>Issue the following Linux command:<br><span style="color:blue;font-weight:bold;font-family:courier;">chmod 750 ~/clients ~/vendors</span><br><br># Issue the '''ls -ld''' and '''ls -lR''' commands (as you did in ''step #8'') to confirm that the permissions for those directories have been changed.<br><br>'''NOTE:''' The '''-R''' option for the '''chmod''' command can change the file permissions <u>recursively</u> within a directory structure.<br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">chmod 750 -R ~/documents</span><br><br># Issue the '''ls -ld''' command to confirm the permissions for the<br>'''~/documents''', '''~/document/memos''' , '''~/documents/reports''', and '''~/documents/contracts''' directories.<br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">ls -lR ~/documents</span><br>What do you noticed happened to the permissions for the regular files contained in those directories.<br>Did those regular file permissions change?<br><br>We will now change permissions for regular text file contained in subdirectories<br>of the '''documents''' directory to: <span style="font-weight:bold;font-family:courier;">r w - r - - - - -</span><br><br># Issue the following Linux commands: <br><span style="color:blue;font-weight:bold;font-family:courier;">chmod 640 ~/documents/memos/memo*.txt<br>chmod 640 ~/documents/reports/report*.txt<br>chmod 640 ~/documents/contracts/contract*.txt</span><br><br># Issue the <span style="font-weight:bold;font-family:courier;">ls -lR</span> command for the '''~/documents''' directory to confirm that those regular file permission have changed.<br><br>Let's run a checking script to make certain you correctly set permissions for those directories and files.<br><br># Issue the following: <span style="color:blue;font-weight:bold;font-family:courier;">~uli101/week4-check-3</span><br><br># If you encounter errors, make corrections and then re-run the checking script until you receive a congratulations message<br>and then continue with this tutorial.<br><br>Let's get some practice setting permissions to allow users to make editing changes to regular files.<br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">chmod ugo-w ~/documents/memos/memo*.txt</span><br><br># Use the <span style="font-weight:bold;font-family:courier;">ls</span> command to verify that those regular file's permissions have changed.<br><br># Using the nano or vi text editor, open the regular file '''~/documents/memos/memo1.txt'''<br>and type in some text and try to save your editing changes.<br>What happened?<br><br># To <u>'''abort'''</u> your editing session in '''vi''': type <span style="color:blue;font-weight:bold;font-family:courier;">:q!</span> and press '''ENTER'''.<br>To <u>'''abort'''</u> your editing changes in '''nano''': type <span style="color:blue;font-weight:bold;font-family:courier;">ctrl-x</span><br>type <span style="color:blue;font-weight:bold;font-family:courier;">n</span> and then press '''ENTER''' when prompted to save editing changes.<br><br># Issue the following Linux command to add write permissions for all files in the '''memos''' directory<br>for yourself (i.e. user): <span style="color:blue;font-weight:bold;font-family:courier;">chmod u+w ~/documents/memos/*</span><br><br># Repeat steps to edit the file '''~/documents/memos/memo1.txt''' (as you did in ''step #20'').<br>Were you able to edit the file and save your editing changes?<br><br># Issue a Linux command to view the <u>contents</u> of the '''~/documents/memos/memo1.txt'''<br>text file that you were able to edit.<br><br># Issue the following Linux command to view permissions for your '''home''' directory: <span style="color:blue;font-weight:bold;font-family:courier;">ls -ld ~</span><br><br>What does execute permissions mean for same group members and other group members<br>in terms of your '''home''' directory?<br><br># Issue the following Linux command to create a new subdirectory: <span style="color:blue;font-weight:bold;font-family:courier;">mkdir ~/shared</span><br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">ls -ld ~/shared</span><br><br>What are the permissions for this newly-created directory?<br>Can other users access the directory pathname '''<span style="font-family:courier">~youruserid/shared</span>''' ?<br><br># Issue the following Linux command (without an argument): <span style="color:blue;font-weight:bold;font-family:courier;">umask</span><br><br>'''NOTE:''' You should see a '''four-digit octal''' number. Drop the leading zero on the left to obtain the '''default umask value'''.<br><br># Perform a '''mathematical calculation''' by taking the octal number '''777''' and <u>subtracting</u><br>the default umask value you determined in the previous step. What is the result?<br><br># Convert that octal number result to a '''binary''' number. What does that represent as newly created directory permissions?<br>Does that correspond to the permissions for the newly created '''~/shared''' directory?<br><br># Repeat the calculation (like in step #28) but with a umask setting of '''077''' to see how this new umask setting would<br>affect permissions of newly-created directories.<br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">umask 077</span><br><br># Issue the following Linux command (without arguments): <span style="color:blue;font-weight:bold;font-family:courier;">umask</span><br><br>NOTE: You should notice the value '''0077'''. By dropping the leading zero to the left,<br> that would provide the default '''umask value of 077'''.<br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">mkdir ~/shared2</span><br><br># Issue the following Linux command: <span style="color:blue;font-weight:bold;font-family:courier;">ls -ld ~/shared2</span><br><br>Do the permissions for this newly created directory match the predicted permissions that you calculated in '''step #30'''?<br><br># Issue the following Linux command to create an empty regular file called '''myfile.txt''' in the '''~/shared2''' directory:<br> <span style="color:blue;font-weight:bold;font-family:courier;">touch ~/shared2/myfile.txt</span><br><br># Use the <span style="font-weight:bold;font-family:courier;">ls -l</span> command to view the permissions for this newly created regular file.<br><br>What do you notice about those permissions?<br><br>Let's run a checking script to make certain you correctly set permissions for those recently-created directories and files.<br><br># Issue the following: <span style="color:blue;font-weight:bold;font-family:courier;">~uli101/week4-check-4</span><br><br>If you encounter errors, make corrections and then re-run the checking script until you receive a congratulations message<br>and then continue with this tutorial.<br><br># Logout of your Matrix account, and then log-back into your Matrix account.<br><br># Issue the following Linux command (without arguments): <span style="color:blue;font-weight:bold;font-family:courier;">umask</span><br><br>What happened? Referring to your notes, what do you need to do to make that umask value persistent?<br><br><span style="color:red;">'''WARNING''':<br>You should be <u>extremely</u> aware of your permissions since you may perform '''marked work''' for <u>other</u> courses on your '''Matrix''' server.<br>You should NOT set permissions to share your work with '''same group''' or '''other group''' members (unless given '''specific permissions instructions from your course professors'''). If students can have access to your directories and project files, they could '''copy''' your work and thus make yourself and other student(s) that copied your work to be charged with '''academic dishonesty'''.</span><br><br>: Complete the Review Questions sections to get additional practice.<br><br>
= LINUX PRACTICE QUESTIONS =
The purpose of this section is to obtain extra practice to help with your assignment #1, quizzes, your midterm, and your final ezamexam.
Here is a link to the MS Word Document of ALL of the questions displayed below but with extra room to answer on the document to
simulate a quiz:
https://ictwiki.cdot.senecacollege.ca/~murray.saululi101/uli101files/uli101_week4_practice.docx
Your instructor may take-up these questions during class. It is up to the student to attend classes in order to obtain the answers to the following questions. Your instructor will NOT provide these answers in any other form (eg. e-mail, etc).
'''Review Questions:'''
# xList the number of digits for the following numbering systems:<ul><li>'''Decimal'''</li><li>'''Binary'''</li><li>'''Octal'''</li><li>'''Hexadecimal'''</li></ul><br># Write a simple chart to show which values are represented for letter '''A - F''' for a hexadecimal number.# x. How many '''binary''' digits does 1 octal digit represent? # xHow many '''binary''' digits does 1 hexadecimal digit represent?[[Image:number-conversion-chart.png|right|450px|thumb|]]# xUse '''manual numbering conversion''' to complete the table displayed to the right.# <ol><li value="6">Write the '''chmod''' command (using the ''symbolic'' method) to set “'''pass-through'''” permissions<br>(eg. <span style="font-family:courier;font-weight:bold;">r w x - - x - - x</span>) for your '''home''' directory using an '''absolute pathname'''.<br>Write a Linux command to verify that permissions where set.# <br><br><br></li><li>Perform a binary to octal numbering conversion for the permissions: '''r w x - - x - - x'''<br>Write single Linux command to set “'''pass-through'''” permissions for your '''home''' directory,<br>using the '''absolute method''' (i.e. octal numbers).<br><br></li><li>Write a single Linux command to '''add read permissions''' for '''same group members''' for the '''~/tests''' directory.<br><br></li><li>Write a single Linux command to '''remove write permissions''' for '''same group members'''<br>and '''other group members''' for the '''~/projects''' directory. Use the ''symbolic'' method.<br><br></li><li>Write a single Linux command to set the permissions for the '''~/assignments''' directory<br> to the following using the '''absolute''' method (i.# e. octal numbers): '''r w x r - x - - x''' <br>Show your work to perform a '''binary''' to '''octal''' conversion.<br>Write the command below using octal numbers and using a relative-to-home pathname.<br><br></li><li>Assume that you just issued the command:<br># <span style="font-family:courier;font-weight:bold">chmod u=rwx,go=x~/linux/content</span><br>What would be the new permissions for the “'''content'''” directory?<br><br></li><li>Assume that you just issued the commands:<br><span style="font-family:courier;font-weight:bold;">umask 077<br>mkdir mydir<br>touch mydir/myfile.txt<br></span><br>What would be the permissions for the newly created '''directory''' and '''regular file'''?<br>(show your work)</li></ol> _________________________________________________________________________________
[[Category:ULI101]]