From a32162e4a26443e9822fe7b572fe9ca0809ca5c9 Mon Sep 17 00:00:00 2001
From: Abhimanyu-dev
We will cover chapter-6 and 7 of this book. This part of the book will provide you with an explained implementation of [Middlewares and REST APIs](https://www.youtube.com/watch?v=1oWPUpMheGk) through routers. |
| Day 7 | **Form processing and Testing**
We will cover chapter-8 and 13 of this book.
Chapter-8 helps you to implement how to process,parse and then store the data(upon validation) as entered by the user on your website.
_Upon completing this chapter, you would have created your own website from scratch._
**Note:** In case you are interested to learn the whole deployment of the web application, you may go through chapters 9 - 12 which basically help you improve your web application by displaying flash messages to users, and security improvements to the website.
Now having made your website, the next important aspect of creating any web-application is its **testing**. Chapter -13 will provide you with the basic syntaxes to creating tests to the components/services you have added to your website. |
+**THE NODE PATHWAY**
+
+| Day Number | Resources |
+| ---------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
+| Day 1 | **Intro to Node**
The [Node.js website](https://nodejs.org/en/about/) describes it as an asynchronous event driven JavaScript runtime, designed to build scalable network applications. So, at its most basic level, Node allows you to run JavaScript code on a machine such as your local computer or a server without having to go through a web browser. To facilitate this, Node has some added functionality that is not found in browser-based JavaScript, such as the ability to read and write local files, create http connections and listen to network requests.
To gain more knowledge about backend you can go through this short article on [MDN](https://developer.mozilla.org/en-US/docs/Learn/Server-side/First_steps) |
+| Day 2 & 3 | **Foundations**
We will begin by installing Node on our systems which can be done from the [official site](https://nodejs.org/en/download/package-manager). Now we are gonna cover the basic topics that you need to go thoroughly before working on the great websites you dream about making. We are linking the official [Node.js docs](https://nodejs.org/en/learn) which might be a bit confusing for people going through docs for the first time but dont worry it will help you out in the long run and you can always ask your doubts in the pclub discord server.
**Getting Started**
[How to run Nod.js scripts from the terminal.](https://nodejs.org/en/learn/command-line/run-nodejs-scripts-from-the-command-line)
[.env files](https://nodejs.org/en/learn/command-line/how-to-read-environment-variables-from-nodejs)
**HTTP Module**
Learn [how to make HTTP requests](https://github.com/nodejs/nodejs.dev/blob/aa4239e87a5adc992fdb709c20aebb5f6da77f86/content/learn/node-js-web-server/node-make-http-requests.en.md) and Node's [http module](https://nodejs.org/api/http.html)
**File System**
We will now learn about how to [read](https://nodejs.org/en/learn/manipulating-files/reading-files-with-nodejs) and [write](https://nodejs.org/en/learn/manipulating-files/writing-files-with-nodejs) files with Node.js and the [fs module](https://github.com/nodejs/nodejs.dev/blob/aa4239e87a5adc992fdb709c20aebb5f6da77f86/content/learn/node-js-modules/node-module-fs.en.md)
**Events**
Now we will go through the [Node events module](https://github.com/nodejs/nodejs.dev/blob/aa4239e87a5adc992fdb709c20aebb5f6da77f86/content/learn/node-js-modules/node-module-events.en.md) and [Event Emitter](https://nodejs.org/en/learn/asynchronous-work/the-nodejs-event-emitter) |
+| Day 4 | **Databasing**
We will now cover storing data for our website. Storing data locally has limitations so we are gonna learn one of the most popular databases MongoDB. MongoDB is a NoSQL database. We are gonna cover SQL and NoSQL database at a later stage for now we just need to know that MongoDB is what everyone is doing right now. To get started with MongoDB go through the [MongoDB University “Introduction to MongoDB” course.](https://learn.mongodb.com/learning-paths/introduction-to-mongodb)|
+| Day 5 | **Introduction To Express**
Finally we begin with the the most popular framework for building a backend in JS : EXPRESS. Go through the entire [MDN documentation on Node.js](https://developer.mozilla.org/en-US/docs/Learn/Server-side/Express_Nodejs/Introduction) It is long but going through it will give you a idea what all you can do with express.
**Templating Engine**
A templating engine is a tool that allows you to insert variables and logic into your views. For instance, you could have a header that updates with the actual user’s name once they’ve logged in, something that is not possible with plain HTML. Now there are two popular options you could go through : [Pug](https://pugjs.org/) which has a learning curve and is quite different than regular HTML and [EJS](https://ejs.co/) which iss a lot more closer to HTML if you are comfortable with it.
**Middleware**
A middleware is just a plain JavaScript function that Express will call for you between the time it receives a network request and the time it fires off a response (i.e. it’s a function that sits in the middle). You will eventually be using several of these functions that will run in a specific sequence for every request. For example, you might have a logger (that prints details of the request to the console), an authenticator (that checks to see if the user is logged in, or otherwise has permission to access whatever they’re requesting) and a static-file server (if the user is requesting a static file then it will send it to them). You can read more about [middlewares here](http://expressjs.com/en/guide/using-middleware.html)
**NOTE**
While going through the resources you should also go through the [MDN tutorial on express](https://developer.mozilla.org/en-US/docs/Learn/Server-side/Express_Nodejs/Tutorial_local_library_website)|
+| Day 6 | **CRUD and MVC**
CRUD stands for: Create, Read, Update and Delete. These are the four basic functions that you will be building into your database driven apps. If you are designing a CRUD interface that means that users can expect to be able to do these 4 things to items in the database (providing they have the appropriate permissions of course). Of course, this is a concept and not some sort of rule that must be followed. You may not want to allow users to do all of these actions, or you may want to limit which users can do what at any given time.
MVC is another common concept in web development and also something that is likely to come up in an interview question. MVC stands for Model, View, Controller and refers to the architecture of your code.
Models are the basic building blocks of your database. So for every type of entry in your DB (book, author, etc. in our Library Project), you’ll create a model that will hold the details of that type of entry. Models define the types of information that get used by your views and controllers.
Views are, of course, the component that generates the UI for your application. In our case, we’ve selected a templating engine that uses data supplied by a controller to display the desired information.
Controllers are the components that decide what view to display and what information is going to be put into it.
Go through this resource to get a better understandding of [MVC](https://www.freecodecamp.org/news/simplified-explanation-to-mvc-5d307796df30/) |
+| Day 7 | **Authentication and Testing**
Creating users and allowing them to log in and out of your web apps is a crucial functionality that we are finally ready to learn! There is quite a bit of setup involved here, but thankfully none of it is too tricky. You’ll be up and running in no time! In this lesson, we’re going to be using [passportJS](https://www.passportjs.org/), an excellent middleware to handle our authentication and sessions for us. Follow this [tutorial here](https://www.theodinproject.com/lessons/nodejs-authentication-basics) to get a better idea of authentication.
Testing is one of the most important parts of webdev that usually most people overlook. We are gonna cover the basics of testing that will get you started on this path. Follow along this [tutorial](https://www.theodinproject.com/lessons/nodejs-testing-routes-and-controllers) to get a hang of it.|
+
**THE DJANGO(PYTHON) PATHWAY**
Django is a high-level Python web framework that encourages rapid development and clean, pragmatic design. That’s why we are providing an alternate pathway for the backend .
@@ -116,16 +127,33 @@ Now that you’ve made a website, how will you share it with the world? How will
| Day Number | Resources |
| ---------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
-| Day 1 | Git
Git is an important version control tool, it is used a lot in the industry. As a developer you must know how to use it.
Let’s start by installing git,
For windows, refer [here](https://nerdschalk.com/how-to-install-and-use-git-on-windows-11/) \| For Linux, refer [here](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git)
Before starting, it is really helpful to get familiar with the terminal, [shell tutorial](https://www.youtube.com/watch?v=Zl7npywCB84). Most commands you see here will also work on windows powershell.
You can learn more about here : [Git Video Tutorial](https://www.youtube.com/watch?v=IHaTbJPdB-s), [Blog on Git](https://jwiegley.github.io/git-from-the-bottom-up/) |
-| Day 2 | Git+Github
Github is a platform where you can keep your code for the world to see! Is also used when multiple people have to contribute to a project.
[What If you mess up?](https://ohshitgit.com/)
To get started with github, we suggest making an account with the IITK email id to avail the student pack, which comes with a lot of benefits. To learn about github, the official docs are a great place to start [Github Docs](https://docs.github.com/en/get-started/quickstart/hello-world).
Also, to get started you need to set up an SSH key, follow [this tutorial](https://www.youtube.com/watch?v=WgZIv5HI44o).
Learn more from here: [Git + Github](https://www.youtube.com/watch?v=HkdAHXoRtos), [Learn git branching](https://learngitbranching.js.org/) |
-| Day 3 | Github Actions
Now that you know about github, it is time to implement some CI/CD using github actions.
[What is CI/CD](https://www.youtube.com/watch?v=scEDHsr3APg&t=14s)
[Workflow for a React App](https://youtu.be/5I37iVCDUTU) |
-| Day 4 | Docker
Docker is a tool for containerizing your applications so that they can run on any platform! It is one of the most important tools used in the industry as it saves a lot of time. Check : [What is Docker?](https://www.freecodecamp.org/news/what-is-docker-used-for-a-docker-container-tutorial-for-beginners/), [Docker Tutorial](https://www.youtube.com/watch?v=pTFZFxd4hOI&t=27s) |
-| Day 5 | Deployment
Now it’s time to deploy your application to a server with everything we have learnt! DigitalOcean is a very good and economical service to do the same.
[In Depth guide to deploy a webapp on DigitalOcean with docker and Github Actions](https://www.youtube.com/watch?v=JsOoUrII3EY) |
-| Day 6 | Deployment
[Deployment Guide - Part 2](https://www.youtube.com/watch?v=hf8wUUrGCgU)
(NOTE: DigitalOcean is a paid service so you don’t need to actually host your website there you can use heroku). |
-| Day 7 | Kubernetes
Kubernetes is a service designed by Google which is used to manage and deploy multiple containers.
[Kubernetes Academy](https://kube.academy/) |
+| Day 1 | **Basics**
***Choosing an operating system***
We know most of you come from a windows or a mac background but when it comes to deevelopment you gotta go for a LINUX or UNIX based operating system. There are a lot of options out there but the most popular ones are UBUNTU, DEBIAN, FEDORA, ARCH, etc. We are not suggesting just shifting from your previous OS, start by dual booting it onto your machine and then slowly make it your daily driver. To get started read this [article](https://ledutokens.medium.com/get-started-with-linux-a-beginners-guide-9ba69b8be53c).
***Using a terminal***
A terminal is simply a text-based interface to the computer, it is used to interact with your computer system via CLI (command line interface). Everything you want to do can be achieved using the terminal and to become a good developer you must learn to live in the terminal. [Here's](https://ubuntu.com/tutorials/command-line-for-beginners#1-overview) a good article to get you started.|
+| Day 2 | **Git**
Git is an important version control tool, it is used a lot in the industry. As a developer you must know how to use it.
Let’s start by installing git,
For windows, refer [here](https://nerdschalk.com/how-to-install-and-use-git-on-windows-11/) \| For Linux, refer [here](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git)
Before starting, it is really helpful to get familiar with the terminal, [shell tutorial](https://www.youtube.com/watch?v=Zl7npywCB84). Most commands you see here will also work on windows powershell.
You can learn more about here : [Git Video Tutorial](https://www.youtube.com/watch?v=IHaTbJPdB-s), [Blog on Git](https://jwiegley.github.io/git-from-the-bottom-up/)
**Git+Github**
Github is a platform where you can keep your code for the world to see! Is also used when multiple people have to contribute to a project.
[What If you mess up?](https://ohshitgit.com/)
To get started with github, we suggest making an account with the IITK email id to avail the student pack, which comes with a lot of benefits. To learn about github, the official docs are a great place to start [Github Docs](https://docs.github.com/en/get-started/quickstart/hello-world).
Also, to get started you need to set up an SSH key, follow [this tutorial](https://www.youtube.com/watch?v=WgZIv5HI44o).
Learn more from here: [Git + Github](https://www.youtube.com/watch?v=HkdAHXoRtos), [Learn git branching](https://learngitbranching.js.org/) |
+| Day 3 | **Github Actions**
Now that you know about github, it is time to implement some CI/CD using github actions.
[What is CI/CD](https://www.youtube.com/watch?v=scEDHsr3APg&t=14s)
[Workflow for a React App](https://youtu.be/5I37iVCDUTU) |
+| Day 4 | **Network Security and Protocols**
As a DevOps engineer you will need to understand the basics of networking protocols, how they work, and how they are used in the real world. To get you started, you should learn about, [TCP/IP](https://www.geeksforgeeks.org/tcp-ip-model/), [HTTP](https://www.geeksforgeeks.org/http-full-form/), [HTTPS](https://www.geeksforgeeks.org/explain-working-of-https/), [FTP](https://www.geeksforgeeks.org/file-transfer-protocol-ftp-in-application-layer/), [SSH](https://www.geeksforgeeks.org/introduction-to-sshsecure-shell-keys/), [SMTP](https://www.geeksforgeeks.org/simple-mail-transfer-protocol-smtp/).
**Web Testing**
Web testing is a software testing technique to test web applications or websites for finding errors and bugs. A web application must be tested properly before it goes to the end-users. Also, testing a web application does not only mean finding common bugs or errors but also testing the quality-related risks associated with the application. [Here](https://usersnap.com/blog/web-application-testing/) is a good resource to get you started. Keep in mind testing is one of the most important aspects of web development and you will keep learning new methods of testing as go along.|
+| Day 5 | **Docker**
Docker is a tool for containerizing your applications so that they can run on any platform! It is one of the most important tools used in the industry as it saves a lot of time. Check : [What is Docker?](https://www.freecodecamp.org/news/what-is-docker-used-for-a-docker-container-tutorial-for-beginners/), [Docker Tutorial](https://www.youtube.com/watch?v=pTFZFxd4hOI&t=27s) |
+| Day 6 | **Deployment**
Now it’s time to deploy your application to a server with everything we have learnt! DigitalOcean is a very good and economical service to do the same.
[In Depth guide to deploy a webapp on DigitalOcean with docker and Github Actions](https://www.youtube.com/watch?v=JsOoUrII3EY) |
+| Day 7 | **Kubernetes**
Kubernetes is a service designed by Google which is used to manage and deploy multiple containers.
[Kubernetes Academy](https://kube.academy/) |
+
+
+
+**Extra Resources**
+We have covered all the necessary resources needed to get you started on your journey as a web developer but there's still a lot more to go but don't worry. The best way to master all these concepts is to just practice and if you ever feel stuck feel free to contact us. We are providing a link of lists that would help you out a lot on your journey of mastering the web.
+* [Web Dev Resources 1](https://web-dev-resources.com/#/)
+* [Web Dev Resources 2](https://github.com/iamismile/web-dev-resources)
+* [Tutorial on MERN stack](https://www.youtube.com/watch?v=K8YELRmUb5o&pp=ygUTbWVybiBmdWxsIHN0YWNrIGFwcA%3D%3D)
+* [Tutorial on Django](https://www.youtube.com/watch?v=rHux0gMZ3Eg&pp=ygUPZGphbmdvIHR1dG9yaWFs)
+* [A few advanced practices](https://muhammedcuma.medium.com/mastering-advanced-web-development-techniques-tools-and-best-practices-36376a949914)
+* [The Odin Project ](https://www.theodinproject.com/)(Covers almost everything from the most basic to advanced stuff)
+
+One last thing that we want to leave you with is choosing the right database for your application. Database are one of the integral parts of your application and deciding on one can be a hassle as you move forward. [Here](https://www.geeksforgeeks.org/which-database-you-should-choose-for-web-developement/) is a good article to read if you want to get an idea.
+
+
**What’s Next?**
+Now that we are familiar with both frontend and backend you can now start making websites and choose a stack to work with. We have given you a lot of options but there are still a lot more out there. The most popular stacks are MERN, MEAN, Ruby on Rails, GO+React and DJANGO.
+
The world of development is vast and there is a lot to explore, this roadmap is in fact just a beginning in your development journey. If you are interested, we suggest you learn more about Next.js(briefly mentioned in week4), MongoDB(a NoSql database), firebase, APIs, Regular Expressions and PostGre(another SQL database, but much more advanced and prevalent in the industry).
Web Development is a gateway to a lot of opportunities in Open Source. The huge benefit of contributing to open source is that you can network with other developers. This means that you'll meet new people and make friends, collaborate with other developers on projects, find mentors and have an opportunity to learn from each other. [Here](https://www.geeksforgeeks.org/best-open-source-programs-for-students-to-participate/amp/) is a list of competitions for students. We wish you all the best for your journey in web development!
@@ -137,3 +165,4 @@ Web Development is a gateway to a lot of opportunities in Open Source. The huge
- Ankush Yadav 9024503686
- Rahul Jha 8700367670
- Shivam Mishra 8604397668
+- Abhimanyu Solanki 8218196261
From 13c9543bd6ce5ce896ad7694bf13021f9767e62f Mon Sep 17 00:00:00 2001
From: Emminence23 , Register on CodeChef ; and then solve the given
problems :
@@ -6830,20 +6818,6 @@-
- Squared | Toph
-- ASCII Progress Bar | Toph
-- Formatted Numbers | Toph
- Codechef - GDTURN
@@ -6572,8 +6562,6 @@Beginner Problems | Codechef -
- Programming Problems for Beginners | Toph