Linux Shell Scripting Projects For Beginners
Address database
Linux Shell Scripting Projects for Beginners – Address Database
data:image/s3,"s3://crabby-images/d16ed/d16ed45ee16bd816f080ff80bbf7d4a2168c41f8" alt=""
About this project
Address Database tool one of the BASH shell based Linux Shell Scripting Projects that is providing various operations to handle a particular database.
About this project
TYPE | Individual project |
DIFFICULTY | Advanced |
ESTIMATED TIME | 50 hours |
PUBLISHED | 15th March, 2021 |
CONTACT | training@emertxe.com |
Introduction
Address Database is one of the BASH shell based Linux Shell Scripting Projects that is providing various operations to handle a particular database. Initially the data-base need to be pre-populated with some data for which the user will be provided with a set of commands (ex: add / modify / delete / search) using which he should be able to modify them. Practically database operations are performed in web applications whenever they are dealing with data. Popularly known as CRUD (Create / Read / Write / Delete) operations, they mainly help to deal with the backend database.
The idea of this project is to implement an address book database management system using BASH Shell scripting and a local text based database. Along with this user functionality, this tool should record all the actions performed along with time-stamps for future references. Since the idea of this tool is to exposure SHELL programming, CSV file is used as a data-base storing entity. By implementing this project you will get a basic understanding of data-base operations, timeout handling, command parsing using various shell commands. By building this Linux Shell Scripting Projects you will be able to get a real feel of Automation and Application Development in Linux.
Requirement Details
Following are the requirements for this Linux Shell Scripting Project. They are categorized into various functional areas.
Activity log file:
- Every activity while the script is to be logged in file named database .log.
- Attach timestamp to every entry.
Working environment settings:
- Should create a directory called “Database” in user’s home directory structure tree, ECEP/LinuxSystems/Projects directory if it doesn’t exist.
- Create a file named “database.csv” under Database directory if it doesn’t exist.
- Check the existence of at least one valid data entry in database.csv.
- If the file is empty, script should only prompt for data addition unless and until it gets a valid entry to display.
User interface:
- The script should have the following functionalities as listed below
- Add Entry
- Search / Edit Entry
Add Entry:
When the user selects the “Add Entry” option it should have the following fields to be added
- Name
- Accept the user entry in any case but convert it to sentence case while storing.
- Accept only alphabets and spaces
- Accept only symbols like “.”, “_”, alphabets, and numbers. Validate for “@” and a “.” after it
- Telephone Number
- Accept only numbers
- Mobile Number
- Add country code (assume Indian customers)
- Validate for 10 digit entry
- Accept only numbers
- Place
- Accept the user entry in any case but convert it to sentence case while storing
- Accept only alphabets and spaces
- Message
- Any character allowed
- No formatting has to be done, user entry has to be captured as is.
- Proper formatted output
When the user finishes all the above fields the information has to be stored with current “date” and “time” automatically
Time-out:
The script should time out if the user input is absent for more than 10 seconds.
Skeleton Code
The skeleton code in a very interesting concept used in Emertxe. By looking into the skeleton code, you will get a clear picture into converting the given requirement into a working solution. This will also take care of important aspects like modularity, clean coding practices, re-usability etc, while building a real-time Linux Shell Scripting Project.
Sample Output
Here are the sample output expected by the end of project execution.
data:image/s3,"s3://crabby-images/f3787/f378769e944ad1c186e6364a8aa431e35fe54d8a" alt="database_1 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 1"
Fig1: Main Menu. Proceeding towards Add Entry
data:image/s3,"s3://crabby-images/47316/47316875f9cb25cf80210c4945f75aa8056522a3" alt="database_2 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 2"
Fig2: Add Entry Screen
data:image/s3,"s3://crabby-images/e7f9c/e7f9ce90d779ec5256c335f63624d577d55b01ad" alt="database_3 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 3"
Fig3: Adding a new Contact with help of Name
data:image/s3,"s3://crabby-images/dcd34/dcd340f1af5c88a53a8965e2612b43e1aff0702d" alt="database_4 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 4"
Fig4: View of added contact. Proceeding to add Mobile Number
data:image/s3,"s3://crabby-images/f7eec/f7eec8f65bde00933da3406595bea2c0cb024664" alt="database_5 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 5"
Fig5: Adding Mobile Number
data:image/s3,"s3://crabby-images/d550a/d550aaf84e9bd861706f9c9fc857b872c1ce0896" alt="database_6 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 6"
Fig6: Updated contact view. Proceeding to previous screen
data:image/s3,"s3://crabby-images/39346/393464e96a65c64505e93ff0935d378dbcee9e52" alt="database_7 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 7"
Fig7: Main Menu. Proceeding towards Search / Edit Entry
data:image/s3,"s3://crabby-images/67831/67831ccea388cd344692dc85c40da37897777dd7" alt="database_8 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 8"
Fig8: Search Menu. Observe the color highlight, The Edit Menu would be similar once the item is searched
data:image/s3,"s3://crabby-images/49e49/49e49c27a4be4bdc34615a6d773a5656a29ae1b7" alt="database_9 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 9"
Fig9: Search Menu. Proceeding towards Search by Name
data:image/s3,"s3://crabby-images/fb4e7/fb4e709cd89f03133f0a10d34c3babd0273adef3" alt="database_10 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 10"
Fig10: The name to be Searched
data:image/s3,"s3://crabby-images/9ce4c/9ce4c62e1f1143b2c59574e3c561e5a4c5cae7ac" alt="database_11 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 11"
Fig11: Search Result. Observe the color highlight, its in Edit Menu now, Proceeding to add Place field
data:image/s3,"s3://crabby-images/8e754/8e754e2e4b9303170b88dbdec841cebfb0433bab" alt="database_12 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 12"
data:image/s3,"s3://crabby-images/7a437/7a437f94fc607fb7f15d5436e37a98c171e9b5fc" alt="database_13 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 13"
Fig13: Updated screen with Place. Proceeding to Save
data:image/s3,"s3://crabby-images/72abc/72abc3f0de7455a7fe8d62971ec92564bf85dc6f" alt="database_14 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 14"
Fig14: Proceeding to Exit Search / Edit Screen
data:image/s3,"s3://crabby-images/dae4c/dae4c6b36015cba47b83da05468ef67d5db4e090" alt="database_15 Linux Shell Scripting Projects for Beginners | Address Database | Project Output - 15"
Fig15: Back to Main Screen. Proceeding to Exit Script
data:image/s3,"s3://crabby-images/cf788/cf788d2b52b835b65a5b7fd1938b08988a88c765" alt="database_16"
Fig16: The contact database in .csv file format
data:image/s3,"s3://crabby-images/51a8a/51a8a81c36db8feaf214c0acc4107e4dfa94b04e" alt="database_17"
Fig17: Assuming multiple entries with same n, This is how the Search result should be shown
data:image/s3,"s3://crabby-images/15b0a/15b0a9d5bd4c6b35d020fd7c11af179fa8903a0e" alt="database_18"
Fig18: Selection of 2nd user to Edit
- Activity log file:
- Working environment settings:
- User interface:
- Add Entry:
- Time-out:
- Fig1: Main Menu. Proceeding towards Add Entry
- Fig2: Add Entry Screen
- Fig3: Adding a new Contact with help of Name
- Fig4: View of added contact. Proceeding to add Mobile Number
- Fig5: Adding Mobile Number
- Fig6: Updated contact view. Proceeding to previous screen
- Fig7: Main Menu. Proceeding towards Search / Edit Entry
- Fig8: Search Menu. Observe the color highlight, The Edit Menu would be similar once the item is searched
- Fig9: Search Menu. Proceeding towards Search by Name
- Fig10: The name to be Searched
- Fig11: Search Result. Observe the color highlight, its in Edit Menu now, Proceeding to add Place field
- Fig13: Updated screen with Place. Proceeding to Save
- Fig14: Proceeding to Exit Search / Edit Screen
- Fig15: Back to Main Screen. Proceeding to Exit Script
- Fig16: The contact database in .csv file format
- Fig17: Assuming multiple entries with same n, This is how the Search result should be shown
- Fig18: Selection of 2nd user to Edit
- Activity log file:
- Working environment settings:
- User interface:
- Add Entry:
- Time-out:
- Fig1: Main Menu. Proceeding towards Add Entry
- Fig2: Add Entry Screen
- Fig3: Adding a new Contact with help of Name
- Fig4: View of added contact. Proceeding to add Mobile Number
- Fig5: Adding Mobile Number
- Fig6: Updated contact view. Proceeding to previous screen
- Fig7: Main Menu. Proceeding towards Search / Edit Entry
- Fig8: Search Menu. Observe the color highlight, The Edit Menu would be similar once the item is searched
- Fig9: Search Menu. Proceeding towards Search by Name
- Fig10: The name to be Searched
- Fig11: Search Result. Observe the color highlight, its in Edit Menu now, Proceeding to add Place field
- Fig13: Updated screen with Place. Proceeding to Save
- Fig14: Proceeding to Exit Search / Edit Screen
- Fig15: Back to Main Screen. Proceeding to Exit Script
- Fig16: The contact database in .csv file format
- Fig17: Assuming multiple entries with same n, This is how the Search result should be shown
- Fig18: Selection of 2nd user to Edit
similar projects
- All
- Foundation
- Speciality
- Upskilling