Focus mode

Node.js

Admin Alanı ve Kullanıcı Silmek

Admin Alanı ve Kullanıcı Silmek

Bu çalışmamızda admin alanı oluşturacağız ve bu admin alanı üzerinden kullanıcıları nasıl sileceğimizi belirteceğiz. Öncelikle admin alanını öğrenci - öğretmen alanlarında olduğu gibi yine dashboard template sayfasını kullanacağız.


<% if(user.role==='admin' ) { %>
----


Kullanıcıları sıralamak için tablo yapısını kullanacağız. Bu tablo yapısı içerisine kullanıcı bilgilerini yerleştiriyoruz.


<table class="table">
  <thead>
    <tr>
    <th scope="col">ID#</th>
    <th scope="col">Email</th>
    <th scope="col">Role</th>
    <th scope="col">Delete</th>
    </tr>
  </thead>
  <tbody>
<% for (let i=0; i< users.length; i++) { %>
    <tr>
    <th scope="row"><%=users[i]._id %></th>
    <td><%=users[i].email %></td>
    <td><%=users[i].role %></td>
    <td><a href="/users/<%= users[i]._id %>?_method=DELETE" 
      onclick="return confirm('ARE YOU SURE')"
      class="btn btn-danger rounded-0 text-white"><span>DELETE</span></a></td>
    </tr>
<% } %>
  </tbody>
 </table>


Şimdi ilgili kullanıcı silme fonksiyonunu yazalım.


exports.deleteUser = async (req, res) => {
  try {    

    await User.findByIdAndRemove(req.params.id)
    await Course.deleteMany({user:req.params.id})

    res.status(200).redirect('/users/dashboard');

  } catch (error) {
    res.status(400).json({
      status: 'fail',
      error,
    });
  }
};


userRoute.js dosyası içerisindeki yönlendirme ise aşağıdadır:


router.route('/:id').delete(authController.deleteUser);


Silme işlemini gerçekleştirecek butonu da aşağıda bulabilirsiniz:


<a href="/users/<%= users[i]._id %>?_method=DELETE" onclick="return confirm('ARE YOU SURE')" class="btn btn-danger rounded-0 text-white"><span>DELETE</span></a>



Proje GitHub


Çalışma Özel GitHub

left-disk

Programs to Accelerate Your Progress in a Software Career

Join our 4-8 month intensive Patika+ bootcamps, start with the fundamentals and gain comprehensive knowledge to kickstart your software career!

right-cube

Comments

You need to enroll in the course to be able to comment!