"micro" framework...?
https://slides.com/superdiana/flask-pt
$whoami
Diana Rodríguez
Google Developer Expert:
- Web Technologies - Google Maps Platform
- Google Cloud Platform - Firebase
Auth0 Ambassador
Microsoft MVP: Developer Technologies
Python Developer Advocate @ Vonage
🚀 https://superdi.dev
🐦 @cotufa82
data:image/s3,"s3://crabby-images/652eb/652eb1e02a5a36db69a5be188280b4d088dcaef4" alt=""
Uma pessoa que aprende algo novo todos os dias !!
data:image/s3,"s3://crabby-images/c4da0/c4da04e97d1fcf0bdf5e79bf3b0a77544a431df4" alt=""
$whoami-NOT
data:image/s3,"s3://crabby-images/6005c/6005c537f9ef5de7ef324c0c431c4a73a5546c90" alt=""
-
Framework Agnostic
-
Weapon of Choice
-
Zero Wars/Mobs/Cults
-
Exemplos "óbvios"
🛁🧼
Flask
"Flask e um microframework de Python que é baseado em Werkzeug, Jinja 2 e boas intenções. Através do Flask, podemos criar aplicaçoes Web e Restful com Python de uma maneira extremamente simple ".
data:image/s3,"s3://crabby-images/01792/01792bb4fbdd115de84304f50deaf6f924122ccc" alt=""
data:image/s3,"s3://crabby-images/49aab/49aab83ada26770e75a06b02331ca28aebe5bbee" alt=""
"Microframework"
data:image/s3,"s3://crabby-images/038c0/038c05426e7fe3035b1cd53c13434a806d185b05" alt=""
data:image/s3,"s3://crabby-images/5be33/5be331ca413c22a4617779d4103e5683f50fc7e6" alt=""
Pros!
- Curva de aprendizagem ✅
- "production ready" ✅
- Boa gestão de rotas
- Sessions! ✅
- Extensible ✅
- Excelente documentação ✅
Cons
- Ninguno
- Complexo para aplicaçoes muito grandes
- Comunidade
- Sem admin
- Sem login o auth
- Sem ORM
- Migrações podem ser complicadas
data:image/s3,"s3://crabby-images/b9457/b94573ca40fced049279f2df2541eb187d8cbd6a" alt=""
data:image/s3,"s3://crabby-images/12f41/12f41971f8b91ea32a4425715169685f4f473e5d" alt=""
Full
Stack
Flask!?
data:image/s3,"s3://crabby-images/39247/392470569f7dce217a860baf3a001228a420ae07" alt=""
data:image/s3,"s3://crabby-images/5d165/5d165abf9c0dba75aefecb920e680644c0b362a2" alt=""
data:image/s3,"s3://crabby-images/13119/131193df8962f8c07b9f82dc66a03be41d5e2b1f" alt=""
data:image/s3,"s3://crabby-images/8e20f/8e20fc3bfb71823b6d344269e183c9635d5d369b" alt=""
data:image/s3,"s3://crabby-images/86a9a/86a9afa712bf091bbc1224f8def65a5cf6c8396e" alt=""
data:image/s3,"s3://crabby-images/0f1e3/0f1e3485183696d70da84eb89ae14761e36cc4c0" alt=""
Rapidinho!
Contexto...
data:image/s3,"s3://crabby-images/02b95/02b951a8623310e7a1365e88efc4f45f34d4cffa" alt=""
data:image/s3,"s3://crabby-images/84b06/84b06deee68c6cc2b20d180e4bd792acf97bf59c" alt=""
data:image/s3,"s3://crabby-images/20e0c/20e0c39b188b1af6c87a54bc2d353dd7318b69b4" alt=""
### layout.hmtl
<!DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" href="{{ url_for('static', filename='css/materialize.min.css') }}">
<link rel="stylesheet" href="{{ url_for('static', filename='css/style.css') }}">
{% block head %}{% endblock %}
</head>
<body>
<header class="container-fluid">
<nav class="teal">
<div class="container">
<div class="row">
<div class="col">
<a href="#" class="brand-logo"><i class="material-icons logo">record_voice_over</i> Scout = Nexmo + Nightscout</a>
</div>
</div>
</div>
</nav>
</header>
<main class="container">
{% block content %}{% endblock %}
</main>
<footer class="page-footer teal">
<div class="footer-copyright">
<div class="container">
Made By <a class="brown-text text-lighten-3">CodeON</a>
</div>
</div>
</footer>
<script language="javascript" src="{{ url_for('static', filename='js/materialize.min.js') }}"></script>
{% block script %}{% endblock %}
</body>
</html>
### login.html
{% extends "layout.html" %}
{% block head %}
<script src="https://apis.google.com/js/platform.js" async defer></script>
<meta name="google-signin-client_id" content="{{ client_id }}">
{% endblock %}
{% block content %}
<div id="user" class="guest">Welcome guest, You need to authenticate</div>
<div class="row">
<div class="col s6 offset-s3">
<div class="card blue-grey darken-1">
<div class="card-content white-text">
<span class="card-title">Login To Enter Scout</span>
<p>This application is going to allow you configure some alerts to your Phone, a Favorite Phone or 5 contact Phones. If you use a nightscout device and you have your api available for external queries. You can use this server and when the glucose level is to low and to high you will receive a call to indicates the glucose level. If you not Answer the call then an sms is sent to your favorite number and other 5 contact numbers.</p>
<div class="g-signin2" data-onsuccess="onSignIn"></div>
</div>
</div>
</div>
</div>
<script language="javascript">
function onSignIn(googleUser) {
var profile = googleUser.getBasicProfile();
if(profile.getId()!==null && profile.getId()!==undefined){
var xhr = new XMLHttpRequest();
xhr.open('POST', '{{ site_url|safe }}/login');
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.onload = function() {
console.log('Signed in as: ' + xhr.responseText);
//Authenticated so redirect to index
window.location = "{{ site_url|safe }}/";
};
xhr.send('idtoken=' + googleUser.getAuthResponse().id_token + "&username=" + profile.getName() + "&email=" + profile.getEmail());
}
}
</script>
### app.py
@app.route('/login',methods=["POST"])
def login():
try:
token = request.form.get("idtoken")
client_id = os.getenv("GOOGLE_CLIENT_ID")
infoid = id_token.verify_oauth2_token(token, google.auth.transport.requests.Request(), client_id)
if infoid['iss'] not in ['accounts.google.com', 'https://accounts.google.com']:
raise ValueError('Wrong issuer.')
userid = infoid['sub']
#Here is a good place to create the session
session["user"] = {"userid": userid, "username": request.form.get("username"), "email": request.form.get("email")}
return userid
except ValueError:
return "Error"
pass
data:image/s3,"s3://crabby-images/5c85e/5c85e0a735628c06475f1d98461e22ed1f3cfbff" alt=""
data:image/s3,"s3://crabby-images/68266/682663f936acc8e9336bd9a3fa2f7517859a608a" alt=""
Assim... 🤔
- Flask é apenas para pequenos projetos?
- Por que chamamos micro framework?
- Você pode fazer tudo o que o Django faz?
- Em quais casos devo usar o Flask em vez do Django?
Em conclusão...
- Excelente opção se você está iniciando o desenvolvimento com Python, e se não ... também 😜
- Não se limita ao desenvolvimento de aplicações simples.
- Coloque e decole à vontade e de acordo com necessidades específicas!
- Depois de dominar o Flask, mudar para Django será muito fácil ...
- ... Ou talvez, não seja necessário!
data:image/s3,"s3://crabby-images/d18e8/d18e84c4c3100e01a2e9e68a98e9533222a9e3d2" alt=""
Micro framework?
data:image/s3,"s3://crabby-images/49aab/49aab83ada26770e75a06b02331ca28aebe5bbee" alt=""
data:image/s3,"s3://crabby-images/0a631/0a63169e92498c427468ad8f7ef390345569d091" alt=""
data:image/s3,"s3://crabby-images/ffb7c/ffb7c4ac5d3e48f602ba887880d9a401ca41a5a1" alt=""
PRAISE YOURSELF
Resources
MUITO OBRIGADA!!
@cotufa82
data:image/s3,"s3://crabby-images/e8648/e864820d350d8596fba36bce7974b5d853f62cf8" alt=""
https://superdi.dev
Flask: Quão "micro" framework?
By Super Diana
Flask: Quão "micro" framework?
- 832