使用Python和Twilio通过短信通知主持视频办公时间。

复制并粘贴的值帐户SID替换的占位符文本TWILIO_ACCOUNT_SID .

然后,导航到控制台的API密钥部分并生成新的API密钥。复制API键的值(同suddenionosphericdisturbance)电离层的突然骚扰秘密替换的占位符文本TWILIO_API_KEY_SIDTWILIO_API_KEY_SECRET .

接下来,如果你还没有带短信功能的aTwilio电话号码,你需要买一个。在此了解如何购买Twilio电话号码。如果你已经有一个Twilio电话号码,它会显示在帐户信息部分,如上面的截图所示。复制此值,并使用它来替换的占位符文本TWILIO_PHONE_NUMBER .

非常重要的是确保这些私有凭据的安全并且不受版本控制,所以如果您正在使用Git,请创建一个_。被增加_文件放在项目的根目录下。您可以在这里列出希望git忽略的文件和目录,以免被跟踪或提交。打开。被增加_在代码编辑器中,将。包封/包围(动词envelop的简写)_文件,如下所示:

.env

现在您已经准备好开始构建您的Flask应用程序了。

构建Flask服务器


创建并打开一个名为_app.py_。这是包含所有Python代码的文件。要设置这个项目,您需要创建一个新的Flask应用程序实例、一个Twilio客户机实例和一个新的TinyDB数据库。

由于这是一个小的教程项目,我们将把数据存储在TinyDB JSON文件中。但是,如果您决定进一步开发这个项目,您可能希望为您部署到生产环境的版本选择不同的数据库。

里面的_app.py_,粘贴以下代码:

import os

from dotenv import load_dotenv

from flask import Flask, render_template, request, abort

from twilio.rest import Client

from tinydb import TinyDB, Query

load_dotenv()

TWILIO_ACCOUNT_SID = os.environ.get(‘TWILIO_ACCOUNT_SID’)

TWILIO_API_KEY_SID = os.environ.get(‘TWILIO_API_KEY_SID’)

TWILIO_API_KEY_SECRET = os.environ.get(‘TWILIO_API_KEY_SECRET’)

TWILIO_PHONE_NUMBER = os.environ.get(‘TWILIO_PHONE_NUMBER’)

client = Client(TWILIO_API_KEY_SID, TWILIO_API_KEY_SECRET, TWILIO_ACCOUNT_SID)

db = TinyDB(‘office_hours.json’)

app = Flask(__name__)

@app.route(‘/’)

def index():

return render_template(‘index.html’)

使用这段代码,您已经创建了一个新的Flask应用程序,其中包含必要的导入、您在上一步中设置的环境变量、一个新的Twilio客户端实例和一个新的数据库。您现在还有一条路线(使用app.route()decorator ),它将呈现一个名为_index.html_,它将包含应用程序的HTML。因为您还没有该文件,所以创建新的_index.html_文件在_模板_目录现在。打开文件并粘贴以下HTML代码:

Office Hours

Office Hours

Create Office Hours Chat

{% if status and status.video_room %}

Success! Office hours room: {{status.video_room.name}} ✅

{% endif %}

这个应用程序的UI并不复杂。它包括一个表单,允许用户输入他们的姓名、电话号码和他们希望接待人们的办公时间视频室的名称。它还有一个显示状态消息的部分,让用户知道房间是否创建成功。在这个HTML文件中,您还引用了一个_样式. css_文件—让我们现在创建它。

创造_static/styles.css_并粘贴以下CSS样式:

.container {

margin-top: 20px;

font-family: sans-serif;

}

h1 {

text-align: center;

}

form {

text-align: center;

}

.data-field {

margin-bottom: 0.5em;

}

input {

padding: 0.6em;

border: 2px solid rgb(177, 189, 233);

border-radius: 5px;

vertical-align: middle;

font-size: 14px;

}

input:focus {

outline: 0;

border-color: #0e364d;

}

label {

text-align: right;

display: inline-block;

width: 6em;

margin: 0 1em 0 0;

}

button {

padding: 0.75em 1em;

border: none;

background-color: rgb(27, 111, 189);

border-radius: 4px;

font-size: 100%;

color: rgb(255, 255, 255);

margin: 0.5em auto;

}

button:focus,

button:hover {

background-color: rgb(88, 166, 240);

}

button:active {

background-color: rgb(177, 189, 233);

}

#status {

margin: 0.5em auto;

text-align: center;

color: rgb(13, 73, 32);

}

现在你的应用看起来更有趣了。

是时候运行你的服务器了。但是,在此之前,在项目的根目录下创建一个名为_。flaskenv_。这是为烧瓶配置添加环境变量的地方。打开_。flaskenv_并添加以下几行:

FLASK_APP=app.py

FLASK_ENV=development

然后,在您的终端中,通过运行以下命令启动服务器:

flask run

一旦服务器启动,您将看到如下日志:

(venv) [office-hours] flask run

* Serving Flask app ‘app.py’ (lazy loading)

* Environment: development

* Debug mode: on

* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)

* Restarting with stat

* Debugger is active!

* Debugger PIN: 290-231-040

如果您打开浏览器http://localhost:5000/,您将能够在那里看到应用程序:

既然已经设置了前端代码,那么是时候编写Python函数了,这些函数将实际控制视频房间的创建以及当有人加入房间时SMS的发送。

创建一个带有自定义超时的视频室


让我们定义一个名为get_or_create_room()这将调用Twilio视频室API来获取或创建视频室。将以下代码粘贴到_app.py_要创建函数:

@app.route(‘/’, methods=[‘POST’])

def get_or_create_room():

identity = request.form.get(‘identity’).strip() or None

phone = request.form.get(‘phone’).strip() or None

room_name = request.form.get(‘room_name’).strip() or None

if identity is None or phone is None or room_name is None:

abort(400, ‘Missing one of: identity, phone, room_name’)

Try to get the room if it exists

video_room_list = client.video.rooms.list(limit=20)

found_video_rooms = [room for room in video_room_list if room.unique_name == room_name]

video_room = found_video_rooms[0] if found_video_rooms else None

request_url = request.url_root

callback_url = f’{request_url}message’

if video_room and video_room.status_callback != callback_url:

abort(400, ‘Status callback URL has changed; please create a room with a different name’)

If the room does not exist, create a new one

if not video_room:

video_room = client.video.rooms.create(

unique_name=room_name,

empty_room_timeout=60,

unused_room_timeout=60,

status_callback=callback_url,

status_callback_method=‘POST’,

)

office_hours_appointment = {

‘identity’: identity,

‘phone’: phone,

‘room_name’: video_room.unique_name,

‘room_sid’: video_room.sid

}

Check whether a record for this office hours meeting already exists

office_hours_meeting = Query()

selected_meeting = db.get(office_hours_meeting.room_sid == video_room.sid)

If a record does not exist, insert a new one

if not selected_meeting:

db.insert(office_hours_appointment)

return render_template(‘index.html’, status={

‘video_room’: {

‘sid’: video_room.sid,

‘name’: video_room.unique_name,

‘empty_room_timeout’: video_room.empty_room_timeout,

‘unused_room_timeout’: video_room.unused_room_timeout,

‘status_callback’: video_room.status_callback

}

})

该函数获取应用程序客户端发送的数据,并验证所需的一切都存在。然后,它获取视频房间名称的变量,并检查是否已经存在同名的活动房间。如果不存在,将使用输入的房间名称创建一个新房间。

该函数的一个关键部分是设置unused_room_timeoutempty_room_timeout。默认情况下,通过Rooms API创建的新的空视频室将保持活动状态5分钟,以便人们加入。如果没有人加入房间,它将关闭并需要重新创建。您可以通过设置unused_room_timeout。该值表示无人加入时房间保持活动状态的分钟数。在办公时间房间的例子中,我们将这个值设置为60,这样即使没有人出现,房间也可以开放一个小时。您可以根据自己的喜好随意设置这个值。

另一个价值,empty_room_timeout,用于设置在最后一个参与者离开后房间应该保持开放多长时间。在办公时间房间的情况下,房间的负责人可能希望在另一个参与者加入时加入房间,在他们的谈话结束后离开房间,然后在另一个参与者加入时再次进入房间。对于这个项目,我们已经设置了empty_room_timeout到60分钟,但是你可以根据自己的喜好随意定制。

这个函数的另一个重要部分是我们在哪里设置一个status_callback。这是一个URL,您的应用程序将通过它接收视频房间内发生的事件的状态信息。房间状态回叫事件的完整列表可以在这里找到。对于这个项目,我们将只跟踪participant-connected事件,因为当有人加入视频房间时,我们希望通知房间创建者,以便他们也可以加入。应用程序将从请求的获取页面地址url_root并添加/messageroute,您将在下一步中创建它。

如果您想了解更多关于视频室的资源属性,请查看这里是Rooms REST API的文档 .

有人加入视频室时发送短信


是时候创建一条路由了,当有人加入视频室时,这条路由将向视频室的创建者发送短信。在…里_app.py_,在下面get_or_create_room(),粘贴以下内容/message路线和send_participant_notification()功能:

@app.route(‘/message’, methods=[‘POST’])

def send_participant_notification():

event = request.values.get(‘StatusCallbackEvent’)

if event == ‘participant-connected’:

room_sid = request.values.get(‘RoomSid’)

office_hours_meeting = Query()

Query for the video meeting by its sid

selected_meeting = db.get(office_hours_meeting.room_sid == room_sid)

participant = request.values.get(‘ParticipantIdentity’)

room_name = selected_meeting.get(‘room_name’)

phone = selected_meeting.get(‘phone’)

identity = selected_meeting.get(‘identity’)

Send an SMS to the creator of the video meeting

client.messages.create(

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**

[外链图片转存中…(img-cFWXtb1J-1712999984119)]

[外链图片转存中…(img-qX25miQ4-1712999984119)]

[外链图片转存中…(img-Llp9zoAz-1712999984120)]

[外链图片转存中…(img-PHq2JFQC-1712999984120)]

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

img
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值