Skip to content

Latest commit

 

History

History
30 lines (21 loc) · 3.17 KB

README.md

File metadata and controls

30 lines (21 loc) · 3.17 KB

semi_restful_CRUD

using Flask and MySQL

Assignment: Semi-Restful Users Create a web app that can handle all of the CRUD operations (create, read, update and destroy) for a table. Use your friends database for the following assignment.

But first, what does REST mean? It's very common for a web application to provide the user interface for creating, reading, updating, or destroying a 'resource' (a table). For example, imagine you want to build a web application that allows the user to create/read/update/destroy users. There are many ways that you can build web applications like this. For example, you could have resources called users, products, pd (short for products) and so forth. You could also have different methods that essentially do the same thing. So, to display user information for user id 1, you could have the URL 'users/1' provide this info or 'users/show/1' or 'users/show_info/1' or 'users/display/1', etc.

Since many web applications perform CRUD operations, you can imagine how confusing this could get if everyone followed different conventions for creating routing and method names for these operations.

A REST or RESTful route is simply a set of route naming conventions that the industry has agreed to follow in order to make it easier to send requests to APIs. It's up to you whether you also follow these rules/conventions but we strongly encourage you to get familiar with the following rules for RESTful routing, as you may be making requests to, or someday creating your own, API.

Right now with Flask, it's not quite possible for you to do the full RESTful architecture, so the exercise below is to help you get somewhat familiar with RESTful routes. Later when you get into other stacks (such as MEAN or Rails), you'll already be somewhat familiar with REST concepts.

Follow the instructions in the wireframe below to build this application in Flask.

alt tag

Make sure to...

Have 7 routes in your server.py. Because we are working with 'users', they might look like: a GET request to /users - calls the index method to display all the users. This will need a template. GET request to /users/new - calls the new method to display a form allowing users to create a new user. This will need a template. GET request /users//edit - calls the edit method to display a form allowing users to edit an existing user with the given id. This will need a template. GET /users/ - calls the show method to display the info for a particular user with given id. This will need a template. POST to /users/create - calls the create method to insert a new user record into our database. This POST should be sent from the form on the page /users/new. Have this redirect to /users/ once created. GET /users//destroy - calls the destroy method to remove a particular user with the given id. Have this redirect back to /users once deleted. POST /users/ - calls the update method to process the submitted form sent from /users//edit. Have this redirect to /users/ once updated. Notice that for every form submission we use a POST method, while we're rendering our templates from get routes.