Authentication system in the forum application #4: Configuration in mailtrap.io and Send verification email

in #utopian-io6 years ago

Repository

https://github.com/python

What Will I Learn?

  • Configuration in mailtrap.io
  • Send verification email

Requirements

  • Basic Python
  • Install Python 3
  • Install Django

Resources

Difficulty

Basic

Tutorial Content

This tutorial is a continuation of the previous tutorial about verifying users with email. Because we use email verification. Of course, we need some configuration because we run the application through our local server. In this tutorial we will learn how to implement our e-mail with the help of new tools, that is mailtrap.io. With this tool, we can send emails from our local server. For those of you who are just following this tutorial, I suggest you follow the previous tutorials.

Use mailtrap.io

We will use an additional tool in the Django application that we created. this tool is mailtrap.io. the use of these tools to help us for development needs when sending emails. Of course, we need a test or check before we send the email feature in the production or real project stage. So mailtrap.io is very useful for those of you who want to test or see emails that are sent during the development process. to start using it we can create an account first.

  • Start using mailtrap.io

The first thing we will do is create an account that we will use to be able to access the dashboard in mailtrap.io. to create an account in mailtrap.io you can use your GitHub account or your Gmail account, as I did in the picture below:

Screenshot_10.png

mailtrap.io is a paid tool but for the sake of simple testing send an email to mailtrap.io that has provided it for free. After we register and log in we will be given access to the dashboard page and on the dashboard, we have an inbox, now the inbox provided for free is a demo inbox.

  • Configuration in mailtrap.io

We can click to enter the demo inbox, now here is an important part of its use, for more details we can see in the picture that I present below:

ezgif.com-video-to-gif (1).gif

There are several configurations that are offered by mailtrap.io, what we will use is the Python language with the Django framework, so we can select the configuration. for more details, we can see in the following picture.

Screenshot_1.png

As we saw in the picture above to configure it in mailtrap.io we have to add the following code in apps/settings.py

EMAIL_HOST = 'smtp.mailtrap.io'
EMAIL_HOST_USER = '9650522bb15611'
EMAIL_HOST_PASSWORD = '9dfe19de3b6fc4'
EMAIL_PORT = '2525'

Screenshot_2.png

Well, now we have finished configuring in mailtrap.io the next step is to create an email activation in the application that we made.

Send email activation

In this section we will continue to create activation emails that we have made in the previous tutorial, In the previous tutorial, we have defined our email template, namely activation_email.html. Well, in this section we will make the template, here is the template that we will create:

  • Create an email template

We will start creating email templates, in this template I have passed a number of variables to render in the template, we can see in the code below to see what variables I passed in this template:

Screenshot_4.png

  • to use the render_to_string () function we must import it first like this from django.template.loader import render_to_string.

  • to use the force_bytes () function we can import it first like the following from django.utils.encoding import force_bytes

and the following is a template that we will render in an email:

activation_email.html

{% autoescape off %}
    Hi, {{user.username}}
    Please click the link below, to activate your account
    http://{{domain}}{% url 'activate' uidb64=uid token=token %}
{% endautoescape %}

Well in this template I will render a link for activation http://{{domain}}{% url 'activate' uidb64=uid token=token %}, the link consists of domains, uids and tokens that have been generated. We haven't created the route yet. we will make it in the next section.

  • Make routing for link activation

We have passed a link in the activation email now we will create the link. I will create a new routing and accept some parameters, namely uid and token. For more details, we can in the code below:

account/urls.py

from django.urls import path
from . import views

urlpatterns = [
    path('signup/', views.SignUp, name='signup'),
    path('password_change/', views.ChangePassword, name='change-password'),
    path('activate/<uidb64>/<token>', views.Activate, name='activate')  // path for activation
]
  • we have created a new path that is path('activate/<uidb64>/<token>', views.Activate, name='activate'). In this routing I will accept the <uidb64> and <token> and define the Activate function in the view class views.Activate and also give an alias name='activate' as we have rendered it in template.

  • And next I will make the Activate function in the view class, this function will only return so that no error occurs.

def Activate(request):
    return

If all the steps above have been completed we can do an experiment like the demonstration that I have made below:

ezgif.com-video-to-gif (2).gif

Screenshot_5.png

We can see in the picture above we have successfully sent an email by sending a verification link to the email we sent. this means our assignment has been completed in this tutorial. In the next tutorial, we will activate the user via the clicked link.

Curriculum

  • Forum app

django#1, django#2, django#3, django#4, django#5, django#6, django#7, django#8, django#8, django#9, django#10, django#11

Proof of work done

https://github.com/milleaduski/forums-django

Sort:  

I thank you for your contribution. Here are my thoughts. Note that, my thoughts are my personal ideas on your post and they are not directly related to the review and scoring unlike the answers I gave in the questionnaire;

  • Language

    • I personally think the usage of the first person reduces the efficiency of the post. I advise you to consider using less first person. Still, this is a personal thought, don't get me wrong! :)

    • There are some sentences which are hard to understand because of the vocabulary and grammar. I advise you to proofread your posts before posting. It can increase the efficiency of your post.

  • Content

    • Thanks for the content, but setting up an e-mail server is kinda trivial for a tutorial concept; I suggest you to delving into less trivial subjects for that reason.

Your contribution has been evaluated according to Utopian policies and guidelines, as well as a predefined set of questions pertaining to the category.

To view those questions and the relevant answers related to your post, click here.


Need help? Chat with us on Discord.

[utopian-moderator]

Thank you for your review, @yokunjon! Keep up the good work!

Hi @duski.harahap!

Your post was upvoted by @steem-ua, new Steem dApp, using UserAuthority for algorithmic post curation!
Your post is eligible for our upvote, thanks to our collaboration with @utopian-io!
Feel free to join our @steem-ua Discord server

Hey, @duski.harahap!

Thanks for contributing on Utopian.
We’re already looking forward to your next contribution!

Get higher incentives and support Utopian.io!
Simply set @utopian.pay as a 5% (or higher) payout beneficiary on your contribution post (via SteemPlus or Steeditor).

Want to chat? Join us on Discord https://discord.gg/h52nFrV.

Vote for Utopian Witness!

Coin Marketplace

STEEM 0.22
TRX 0.20
JST 0.034
BTC 92511.70
ETH 3099.35
USDT 1.00
SBD 3.12