Web2py - Kontrol Akses

Autentikasi

Hampir setiap aplikasi harus dapat mengautentikasi pengguna dan mengatur izin. web2py hadir dengan kontrol akses berbasis peran yang ekstensif dan dapat disesuaikanmechanism.web2py. Ini juga mendukung protokol, seperti CAS, OpenID, OAuth 1.0, LDAP, PAM, X509, dan banyak lagi.

web2py menyertakan mekanisme yang dikenal sebagai mekanisme Kontrol Akses Berbasis Peran (RBAC) yang merupakan pendekatan untuk membatasi akses sistem ke pengguna yang berwenang. Kelas web2py yang mengimplementasikan RBAC disebut Auth.

Lihatlah skema yang diberikan di bawah ini.

Auth mendefinisikan tabel berikut -

Sr Tidak Nama & Deskripsi Tabel
1

auth_user

menyimpan nama, alamat email, kata sandi, dan status pengguna.

2

auth_group

menyimpan grup atau peran untuk pengguna dalam struktur banyak ke banyak

3

auth_membership

Menyimpan informasi dari tautan pengguna dan grup dalam struktur banyak-ke-banyak

4

auth_permission

Tabel menautkan grup dan izin.

5

auth_event

mencatat perubahan di tabel lain dan berhasil mengakses

6

auth_cas

Ini digunakan untuk Central Authentication Service

Menyesuaikan Auth

Ada dua cara untuk menyesuaikan Auth.

  • Untuk menentukan kebiasaan db.auth_user tabel dari awal.

  • Biarkan web2py mendefinisikan auth meja.

Mari kita lihat metode terakhir untuk mendefinisikan authmeja. Dalamdb.py model, ganti baris berikut -

auth.define_tables()

Gantilah dengan kode berikut -

auth.settings.extra_fields['auth_user'] = [
   Field('phone_number',requires = IS_MATCH('\d{3}\-\d{3}\-\d{4}')),
   Field('address','text')
]

auth.define_tables(username = True)

Asumsinya adalah setiap pengguna terdiri dari nomor telepon, nama pengguna dan alamat.

auth.settings.extra_fieldsadalah kamus bidang ekstra. Kuncinya adalah nama tabel autentikasi yang akan ditambahkan kolom ekstra. Nilainya adalah daftar bidang ekstra. Di sini, kami telah menambahkan dua bidang tambahan,phone_number and address.

usernameharus diperlakukan dengan cara khusus, karena terlibat dalam proses otentikasi, yang biasanya didasarkan pada bidang email. Dengan meneruskan argumen nama pengguna ke baris berikut, itu diinformasikan ke web2py bahwa kami menginginkan bidang nama pengguna, dan kami ingin menggunakannya untuk login daripada bidang email. Ini berfungsi seperti kunci utama.

auth.define_tables(username = True)

Nama pengguna diperlakukan sebagai nilai unik. Mungkin ada kasus ketika pendaftaran terjadi di luar formulir pendaftaran normal. Itu juga terjadi, bahwa pengguna baru dipaksa untuk masuk, untuk menyelesaikan pendaftaran mereka.

Ini bisa dilakukan dengan menggunakan bidang dummy, complete_registration yang diatur ke False secara default, dan disetel ke True saat mereka memperbarui profilnya.

auth.settings.extra_fields['auth_user'] = [
   Field('phone_number',requires = IS_MATCH('\d{3}\-\d{3}\-\d{4}'),
   comment = "i.e. 123-123-1234"),
   Field('address','text'),
   Field('complete_registration',default = False,update = True,
   writable = False, readable = False)
]

auth.define_tables(username = True)

Skenario ini mungkin bermaksud pengguna baru, setelah login, untuk menyelesaikan pendaftaran mereka.

Di db.py, di folder model, kita dapat menambahkan kode berikut -

if auth.user and not auth.user.complete_registration:
if not (request.controller,request.function) == ('default','user'):
   redirect(URL('default','user/profile'))

Ini akan memaksa pengguna baru untuk mengedit profil mereka sesuai persyaratan.

Otorisasi

Ini adalah proses memberikan beberapa akses atau memberikan izin sesuatu kepada pengguna.

Di web2py setelah pengguna baru dibuat atau didaftarkan, grup baru dibuat untuk menampung pengguna. Peran pengguna baru secara konvensional disebut sebagai“user_[id]” di mana id adalah identifikasi unik pengguna.

Nilai default untuk pembuatan grup baru adalah -

auth.settings.create_user_groups = "user_%(id)s"

Pembuatan grup di antara pengguna dapat dinonaktifkan oleh -

auth.settings.create_user_groups = None

Pembuatan, pemberian akses ke anggota tertentu dan izin dapat dicapai secara terprogram dengan bantuan appadmin juga.

Beberapa implementasi terdaftar sebagai berikut -

Sr Tidak Perintah & Penggunaan
1

auth.add_group('role', 'description')

mengembalikan id dari grup yang baru dibuat.

2

auth.del_group(group_id)

Menghapus grup dengan id yang ditentukan

3

auth.del_group(auth.id_group('user_7'))

Menghapus grup pengguna dengan identifikasi yang diberikan.

4

auth.user_group(user_id)

Menampilkan nilai id grup yang terkait secara unik untuk pengguna tertentu.

5

auth.add_membership(group_id, user_id)

Mengembalikan nilai user_id untuk group_id tertentu

6

auth.del_membership(group_id, user_id)

Cabut akses member_id yang diberikan yaitu user_id dari grup tertentu.

7

auth.has_membership(group_id, user_id, role)

Memeriksa apakah user_id termasuk dalam grup tertentu.

Central Authentication Service (CAS)

web2py menyediakan standar industri yaitu, Layanan Otentikasi Klien - CAS untuk klien dan server built-in web2py. Ini adalah alat otentikasi pihak ketiga.

Ini adalah protokol terbuka untuk otentikasi terdistribusi. Cara kerja CAS adalah sebagai berikut -

  • Jika pengguna mengunjungi situs web, protokol memeriksa apakah pengguna diautentikasi.

  • Jika pengguna tidak diautentikasi ke aplikasi, protokol akan mengarahkan ke halaman tempat pengguna dapat mendaftar atau masuk ke aplikasi.

  • Jika pendaftaran selesai, pengguna menerima email. Pendaftaran tidak selesai sampai dan kecuali pengguna memverifikasi email tersebut.

  • Setelah pendaftaran berhasil, pengguna diautentikasi dengan kunci, yang digunakan oleh peralatan CAS.

  • Kunci digunakan untuk mendapatkan kredensial pengguna melalui permintaan HTTP, yang disetel di latar belakang.