NestJS and DrizzleOrm question
Please tell me, I have a very complicated idea.
I'm making an event app, events can be created by clubs, and a club can have people with the roles of President and Staff
and only they can create events.
I have a roles table.
as well as the user_roles many to many table, a user can be the president of many clubs, or be on the staff of other clubs
The problem now is that I'm trying to implement a method to get information about which clubs the user has access to create events.
data:image/s3,"s3://crabby-images/f0cdb/f0cdb7436d14c32b37f52ef490df988c339b7da0" alt="No description"
8 Replies
data:image/s3,"s3://crabby-images/674ba/674ba03c13a5b640a087e76e649f27a376859a34" alt="No description"
I guess I need to join the tables, because now I need to compare by id whether the user has the id of the role through which he has access, but in the code I need to achieve a comparison with the enum like current user roles = [President, Staff]
data:image/s3,"s3://crabby-images/7525b/7525b3bc2a74f81f7cfcbd7d355c7d7ad723a0a6" alt="No description"
sorry if it's confusing, I hope I explained the problem clearly, I don't know how to approach the solution.
so far, this is the answer, although HobbyHorsing should not be because the role corresponds to the role of a Member.
data:image/s3,"s3://crabby-images/d1dd1/d1dd140b9adea6f4995d5f0819de6d5a1bec8851" alt="No description"
data:image/s3,"s3://crabby-images/baad6/baad6a6fafc6f41b72f7e6126c26b84ee2cc28b1" alt="No description"
data:image/s3,"s3://crabby-images/a2c3d/a2c3d5173c8c29726772cef3d6c62f611b9f6fe1" alt="No description"
please tell me how to write this with drizzle
so far, I only see a solution to take and filter the backend response in the map, where it explicitly checks the role ids (since they will not change)
but I would like to compare it with the name of the role, and do it through the database, not the map.
@👾Rnbsov are you using laravel?
If you're using laravel, mysql
you can do like this
First define
- User.php
class User extends Authenticatable
{
public function roles()
{
return $this->hasMany(UserRole::class);
}
public function authorizedClubs()
{
return $this->belongsToMany(Club::class, 'user_roles')
->whereIn('user_roles.role_id', function ($query) {
$query->select('id')
->from('roles')
->whereIn('name', ['President', 'Staff']);
});
}
}
- Club.php
class Club extends Model
{
public function users()
{
return $this->belongsToMany(User::class, 'user_roles');
}
}
On your controller, you can get clubs like this easliy:
$user = Auth::user();
$clubs = $user->authorizedClubs()->get();
no, but thanks!
I made a sql query out of your code
thanks!
@👾Rnbsov awesome, sql query is more scalable and fast method than using pre-built in mvc