Pilih preferensi cookie Anda

Kami menggunakan cookie penting serta alat serupa yang diperlukan untuk menyediakan situs dan layanan. Kami menggunakan cookie performa untuk mengumpulkan statistik anonim sehingga kami dapat memahami cara pelanggan menggunakan situs dan melakukan perbaikan. Cookie penting tidak dapat dinonaktifkan, tetapi Anda dapat mengklik “Kustom” atau “Tolak” untuk menolak cookie performa.

Jika Anda setuju, AWS dan pihak ketiga yang disetujui juga akan menggunakan cookie untuk menyediakan fitur situs yang berguna, mengingat preferensi Anda, dan menampilkan konten yang relevan, termasuk iklan yang relevan. Untuk menerima atau menolak semua cookie yang tidak penting, klik “Terima” atau “Tolak”. Untuk membuat pilihan yang lebih detail, klik “Kustomisasi”.

Mengkonfigurasi dan menggunakan resolver pipeline di () AWS AppSync VTL

Mode fokus
Mengkonfigurasi dan menggunakan resolver pipeline di () AWS AppSync VTL - AWS AppSync

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

catatan

Kami sekarang terutama mendukung runtime APPSYNC _JS dan dokumentasinya. Harap pertimbangkan untuk menggunakan runtime APPSYNC _JS dan panduannya di sini.

AWS AppSync mengeksekusi resolver pada bidang GraphQL. Dalam beberapa kasus, aplikasi memerlukan eksekusi beberapa operasi untuk menyelesaikan satu bidang GraphQL. Dengan resolver pipeline, pengembang sekarang dapat membuat operasi yang disebut Fungsi dan menjalankannya secara berurutan. Pipeline resolver berguna untuk aplikasi yang, misalnya, memerlukan melakukan pemeriksaan otorisasi sebelum mengambil data untuk bidang.

Pipeline resolver terdiri dari template Sebelum pemetaan, template After mapping, dan daftar Functions. Setiap Fungsi memiliki template pemetaan permintaan dan respons yang dijalankan terhadap sumber data. Karena penyelesai pipa mendelegasikan eksekusi ke daftar fungsi, oleh karena itu tidak ditautkan ke sumber data apa pun. Resolver dan fungsi unit adalah primitif yang menjalankan operasi terhadap sumber data. Lihat ikhtisar template pemetaan Resolver untuk informasi selengkapnya.

Langkah 1: Membuat resolver pipa

Di AWS AppSync konsol, buka halaman Skema.

Simpan skema berikut:

schema { query: Query mutation: Mutation } type Mutation { signUp(input: Signup): User } type Query { getUser(id: ID!): User } input Signup { username: String! email: String! } type User { id: ID! username: String email: AWSEmail }

Kita akan memasang resolver pipa ke signUpbidang pada tipe Mutasi. Pada tipe Mutasi di sisi kanan, pilih Lampirkan di sebelah bidang signUp mutasi. Pada halaman create resolver, klik Actions, lalu Update runtime. PilihPipeline Resolver, lalu pilihVTL, lalu pilih Perbarui. Halaman sekarang harus menampilkan tiga bagian: area teks Sebelum memetakan template, bagian Fungsi, dan area teks template Setelah pemetaan.

Pipeline resolver kami mendaftarkan pengguna dengan terlebih dahulu memvalidasi input alamat email dan kemudian menyimpan pengguna dalam sistem. Kita akan merangkum validasi email di dalam validateEmailfungsi, dan menyimpan pengguna di dalam fungsi. saveUser validateEmailFungsi dijalankan terlebih dahulu, dan jika email valid, maka saveUserfungsi dijalankan.

Alur eksekusi adalah sebagai berikut:

  1. Mutasi. signUp Templat pemetaan permintaan resolver

  2. validateEmail fungsi

  3. saveUser fungsi

  4. Mutasi. signUp Templat pemetaan respons resolver

Karena kita mungkin akan menggunakan kembali validateEmailfungsi di resolver lain pada kitaAPI, kita ingin menghindari mengakses $ctx.args karena ini akan berubah dari satu bidang GraphQL ke bidang GraphQL lainnya. Sebagai gantinya, kita dapat menggunakan $ctx.stash untuk menyimpan atribut email dari argumen field signUp(input: Signup) input.

BEFORETemplate pemetaan:

## store email input field into a generic email key $util.qr($ctx.stash.put("email", $ctx.args.input.email)) {}

Konsol menyediakan template AFTERpemetaan passthrough default yang akan kita gunakan:

$util.toJson($ctx.result)

Pilih Buat atau Simpan untuk memperbarui resolver.

Langkah 2: Membuat fungsi

Dari halaman resolver pipeline, di bagian Functions, klik Add function, lalu Create new function. Dimungkinkan juga untuk membuat fungsi tanpa melalui halaman resolver; untuk melakukan ini, di AWS AppSync konsol, buka halaman Fungsi. Pilih tombol Buat fungsi. Mari buat fungsi yang memeriksa apakah email valid dan berasal dari domain tertentu. Jika email tidak valid, fungsi tersebut menimbulkan kesalahan. Jika tidak, itu meneruskan input apa pun yang diberikan.

Pada halaman fungsi baru, pilih Tindakan, lalu Perbarui runtime. PilihVTL, lalu Perbarui. Pastikan Anda telah membuat sumber data dari NONEjenis tersebut. Pilih sumber data ini di daftar Nama sumber data. Untuk nama fungsi, masukkanvalidateEmail. Di area kode fungsi, timpa semuanya dengan cuplikan ini:

#set($valid = $util.matches("^[a-zA-Z0-9_.+-]+@(?:(?:[a-zA-Z0-9-]+\.)?[a-zA-Z]+\.)?(myvaliddomain)\.com", $ctx.stash.email)) #if (!$valid) $util.error("$ctx.stash.email is not a valid email.") #end { "payload": { "email": $util.toJson(${ctx.stash.email}) } }

Tempelkan ini ke template pemetaan respons:

$util.toJson($ctx.result)

Tinjau perubahan Anda, lalu pilih Buat. Kami baru saja menciptakan validateEmailfungsi kami. Ulangi langkah-langkah ini untuk membuat saveUserfungsi dengan template pemetaan permintaan dan respons berikut (Demi kesederhanaan, kami menggunakan sumber NONEdata dan berpura-pura pengguna telah disimpan dalam sistem setelah fungsi dijalankan. ):

Permintaan template pemetaan:

## $ctx.prev.result contains the signup input values. We could have also ## used $ctx.args.input. { "payload": $util.toJson($ctx.prev.result) }

Templat pemetaan respons:

## an id is required so let's add a unique random identifier to the output $util.qr($ctx.result.put("id", $util.autoId())) $util.toJson($ctx.result)

Kami baru saja menciptakan saveUserfungsi kami.

Langkah 3: Menambahkan fungsi ke resolver pipa

Fungsi kita seharusnya ditambahkan secara otomatis ke resolver pipeline yang baru saja kita buat. Jika ini bukan masalahnya, atau Anda membuat fungsi melalui halaman Fungsi, Anda dapat mengklik Tambahkan fungsi pada halaman resolver untuk melampirkannya. Tambahkan saveUserfungsi validateEmaildan fungsi ke resolver. validateEmailFungsi harus ditempatkan sebelum saveUserfungsi. Saat Anda menambahkan lebih banyak fungsi, Anda dapat menggunakan opsi pindah ke atas dan bergerak ke bawah untuk mengatur ulang urutan eksekusi fungsi Anda. Tinjau perubahan Anda, lalu pilih Simpan.

Langkah 4: Menjalankan kueri

Di AWS AppSync konsol, buka halaman Kueri. Di penjelajah, pastikan Anda menggunakan mutasi Anda. Jika tidak, pilih Mutation di daftar drop-down, lalu pilih+. Masukkan kueri berikut:

mutation { signUp(input: { email: "nadia@myvaliddomain.com" username: "nadia" }) { id email } }

Ini harus mengembalikan sesuatu seperti:

{ "data": { "signUp": { "id": "256b6cc2-4694-46f4-a55e-8cb14cc5d7fc", "email": "nadia@myvaliddomain.com" } } }

Kami telah berhasil mendaftarkan pengguna kami dan memvalidasi email input menggunakan resolver pipeline. Untuk mengikuti tutorial yang lebih lengkap yang berfokus pada resolver pipeline, Anda dapat pergi ke Tutorial: Pipeline Resolvers

PrivasiSyarat situsPreferensi cookie
© 2025, Amazon Web Services, Inc. atau afiliasinya. Semua hak dilindungi undang-undang.