Crie um bot para Telegram e gerencie a escala de plantonistas
O uso de bots em aplicativos de mensagens como o Telegram tem se tornado cada vez mais comum. Eles podem ser utilizados para as mais diversas finalidades, desde tirar dúvidas até realizar tarefas específicas. Neste artigo, apresentaremos um exemplo de bot para o Telegram que permite o cadastro e consulta de plantonistas.
[ Hits: 3.029 ]
Por: Leonardo Berbert Gomes em 04/04/2023 | Blog: https://www.linkedin.com/in/leoberbert
import sqlite3 # Conectar ao banco de dados conn = sqlite3.connect('plantao.db') # Criar uma tabela chamada plantao conn.execute(''' CREATE TABLE plantao ( plantonista TEXT, data TEXT ); ''') # Fechar a conexão com o banco de dados conn.close()
from flask import Flask, render_template, request, redirect, url_for from flask_httpauth import HTTPBasicAuth import sqlite3 import logging log = logging.getLogger('werkzeug') log.setLevel(logging.ERROR) app = Flask(__name__) auth = HTTPBasicAuth() # Define o caminho para o banco de dados DB_PATH = 'plantao.db' # Dicionário com os usuários e senhas USERS = { "plantonista": "guarana" } # Função que verifica se um usuário está autorizado @auth.verify_password def verify(username, password): if not (username and password): return False return USERS.get(username) == password @app.route('/plantao', methods=['GET', 'POST']) @auth.login_required def cadastro_plantonista(): if request.method == 'POST': plantonista = request.form['plantonista'] data = request.form['data'] # Conecta ao banco de dados conn = sqlite3.connect(DB_PATH) # Insere os dados na tabela "plantao" cur = conn.cursor() cur.execute("INSERT INTO plantao (plantonista, data) VALUES (?, ?)", (plantonista, data)) conn.commit() # Fecha a conexão com o banco de dados conn.close() # Redireciona para a página de confirmação return redirect(url_for('cadastro_sucesso', plantonista=plantonista, data=data)) return render_template('index.html') @app.route('/cadastro_sucesso') def cadastro_sucesso(): plantonista = request.args.get('plantonista') data = request.args.get('data') return render_template('cadastro_sucesso.html', plantonista=plantonista, data=data) if __name__ == '__main__': app.run(host='0.0.0.0',debug=True,port=5000)
import sqlite3 # Estabelecendo conexão com o banco de dados conn = sqlite3.connect('plantao.db') # Criando um cursor para executar comandos SQL cursor = conn.cursor() # Executando uma consulta SELECT em uma tabela cursor.execute("SELECT * FROM plantao") # Obtendo todos os resultados da consulta resultados = cursor.fetchall() # Imprimindo os resultados na tela for linha in resultados: print(linha) # Fechando a conexão com o banco de dados conn.close()
Monitorando as conversas do MSN
Centralizando logs com Promtail + Loki + Grafana
SuperDNS: Solução definitiva para DNS dinâmico
Detectando vulnerabilidades com o Nessus
Python: automatizando a extração de informações na web com expressões regulares
Programe em Python no jogo Minecraft com seu filho ou sozinho
Clicador automático de Tinder com Python
RapidScan - Multi-Tool WEB Vulnerability Scanner
Título: Descobrindo o IP externo da VPN no Linux
Armazenando a senha de sua carteira Bitcoin de forma segura no Linux
Enviar mensagem ao usuário trabalhando com as opções do php.ini
Encontre seus arquivos facilmente com o Drill
Mouse Logitech MX Ergo Advanced Wireless Trackball no Linux
Compartilhamento de Rede com samba em modo Público/Anônimo de forma simples, rápido e fácil
Cups: Mapear/listar todas as impressoras de outro Servidor CUPS de forma rápida e fácil
Agora temos uma assistente virtual no fórum!!! (244)
Alternar as janelas clicando na barra de tarefas (0)
Ubuntu 22.04 / Bluethooth - Falha na conexão BlueZ | Não conecta caixa... (6)
Olá quais distribuições recomendam para usar no dia a dia. (10)