completed login api

This commit is contained in:
kicap1992
2022-04-22 12:47:13 +08:00
parent b5752f111d
commit 73ea1fe511
4 changed files with 544 additions and 547 deletions

817
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -22,9 +22,14 @@ const pengirimSchema = new mongoose.Schema({
type: String, type: String,
required: true required: true
}, },
status: {
type: String,
},
photo_url: { photo_url: {
type: String, type: String,
// required: true required: true,
default: 'Evaluasi'
}, },
created_at: { created_at: {
type: Date, type: Date,

View File

@ -13,124 +13,71 @@ const kenderaan_kurir_folder_id = process.env.KENDERAAN_KURIR_FOLDER_ID;
// crate get // crate get
router.get('/', async (req, res) => { router.get('/', async (req, res) => {
console.log("ada request login");
// console.log(await googlenya.uploadFile('hehehehhe')) // console the parameter from the url
res.send({ status: true, msg: 'sini dia' }); // console.log(req.query);
})
//create get for daftar
router.post('/daftar', async (req, res) => {
try { try {
// console.log(req) let username = req.query.username;
role = req.body.role; let password = req.query.password;
let responsenya; let role = req.query.role;
// if username, password and role is empty or null
if (role == 'pengirim') { if (!username || !password || !role) {
// console.log("ini untuk pengirim"); res.status(400).send({
// cek if req.body.no_telp is exist on database return true or false status: false,
let isExist = await pengirimModel.findOne({ no_telp: req.body.no_telp }); message: 'username, password and role is required'
if (isExist) { });
res.status(400).send({ message: 'No Telpon Sudah Terdaftar' }); return;
return;
}
// check if req.body.email is exist on database return true or false
let isExistEmail = await pengirimModel.findOne({ email: req.body.email });
if (isExistEmail) {
res.status(400).send({ message: 'Email Sudah Terdaftar' });
return;
}
let new_pengirim = new pengirimModel(req.body);
// add photo_url to pengirim
// check if files.photo exist
if (req.files.photo) {
let id_photo = await googlenya.uploadFile(new_pengirim._id + ".jpg", req.files.photo.path, pengirim_folder_id, "ini photo pengirim");
new_pengirim.photo_url = `https://drive.google.com/uc?export=view&id=${id_photo}`;
}
// console.log(new_pengirim);
// console.log(pengirim_folder_id)
await new_pengirim.save();
responsenya = new_pengirim;
} else if (role == 'kurir') {
// check if req.body.nik is exists
let isExist = await kurirModel.findOne({ nik: req.body.nik });
if (isExist) {
res.status(400).send({
status: false,
message: 'NIK Sudah Terdaftar'
});
return;
}
// check if req.body.no_telp is exists
let isExist2 = await kurirModel.findOne({ no_telp: req.body.no_telp });
if (isExist2) {
res.status(400).send({
status: false,
message: 'No Telpon Sudah Terdaftar'
});
return;
}
// check if req.body.email is exists
let isExist3 = await kurirModel.findOne({ email: req.body.email });
if (isExist3) {
res.status(400).send({
status: false,
message: 'Email Sudah Terdaftar'
});
return;
}
// check if req.files.photo and req.files.ktp_photo and req.files.ktp_holding_photo and req.files.kenderaan_photo exist
if (!req.files.photo || !req.files.ktp_photo || !req.files.ktp_holding_photo || !req.files.kenderaan_photo) {
res.status(400).send({
status: false,
message: 'File tidak boleh kosong'
});
return;
}
let new_kurir = new kurirModel(req.body);
// add photo_url to new_kurir
let id_photo = googlenya.uploadFile(new_kurir._id + ".jpg", req.files.photo.path, kurir_folder_id, "ini photo kurir");
// add ktp_url to new_kurir
let id_ktp = googlenya.uploadFile("ktp_" + new_kurir._id + ".jpg", req.files.ktp_photo.path, ktp_kurir_folder_id, "ini ktp kurir");
// add ktp_holding_url to new_kurir
let id_ktp_holding = googlenya.uploadFile("ktp_holding_" + new_kurir._id + ".jpg", req.files.ktp_holding_photo.path, ktp_holding_kurir_folder_id, "ini ktp holding kurir");
// add kenderaan_url to kurir
let id_kenderaan = googlenya.uploadFile("kenderaan_" + new_kurir._id + ".jpg", req.files.kenderaan_photo.path, kenderaan_kurir_folder_id, "ini kenderaan kurir");
new_kurir.photo_url = `https://drive.google.com/uc?export=view&id=${await id_photo}`
new_kurir.ktp_url = `https://drive.google.com/uc?export=view&id=${await id_ktp}`
new_kurir.ktp_holding_url = `https://drive.google.com/uc?export=view&id=${await id_ktp_holding}`
new_kurir.kenderaan_url = `https://drive.google.com/uc?export=view&id=${await id_kenderaan}`
console.log(new_kurir)
await new_kurir.save();
responsenya = new_kurir;
} }
res.send({ status: true, data: responsenya });
// if role is not equal to 'pengirim' or 'kurir'
if (role !== 'pengirim' && role !== 'kurir') {
res.status(400).send({
status: false,
message: 'Role is wrong'
});
return;
}
// check from loginUserModel
let user = await loginUserModel.findOne({
username: username,
password: password,
role: role
});
// if user is not found
if (!user) {
res.status(400).send({
status :false,
message: 'Username dan Password Salah',
focus: 'username'
});
return;
}
console.log(user);
res.status(200).send({
status: true,
message: 'Login Success',
data: user
})
} catch (error) { } catch (error) {
res.status(500).send({ status: false, data: error }); console.log(error);
res.status(500).send({ status: false, message: error.message });
} }
// res.send('sini untuk daftar'); // console.log(await googlenya.uploadFile('hehehehhe'))
// res.send({ status: true, message: 'sini diaadasd' });
}) })
router.post('/daftar1', async (req, res) => { router.post('/daftar1', async (req, res) => {
try { try {
console.log("ada org request") console.log("ada org request")
@ -143,8 +90,8 @@ router.post('/daftar1', async (req, res) => {
} }
data = JSON.parse(data); data = JSON.parse(data);
if(data.role == 'kurir'){ if (data.role == 'kurir') {
let isExist = await kurirModel.findOne({ nik: data.nik }); let isExist = await kurirModel.findOne({ nik: data.nik });
// console.log(isExist.status + "ini adalag evaluasi"); // console.log(isExist.status + "ini adalag evaluasi");
// console.log("ini untuk nik") // console.log("ini untuk nik")
@ -154,7 +101,7 @@ router.post('/daftar1', async (req, res) => {
res.status(400).send({ res.status(400).send({
status: false, status: false,
message: message, message: message,
focus : 'nik' focus: 'nik'
}); });
return; return;
} }
@ -168,7 +115,7 @@ router.post('/daftar1', async (req, res) => {
res.status(400).send({ res.status(400).send({
status: false, status: false,
message: message, message: message,
focus : 'no_telp' focus: 'no_telp'
}); });
return; return;
} }
@ -182,7 +129,7 @@ router.post('/daftar1', async (req, res) => {
res.status(400).send({ res.status(400).send({
status: false, status: false,
message: message, message: message,
focus : 'email' focus: 'email'
}); });
return; return;
} }
@ -222,7 +169,7 @@ router.post('/daftar1', async (req, res) => {
new_kurir.kenderaan_url = `https://drive.google.com/uc?export=view&id=${await id_kenderaan}` new_kurir.kenderaan_url = `https://drive.google.com/uc?export=view&id=${await id_kenderaan}`
console.log(new_kurir) console.log(new_kurir)
let new_login = new loginUserModel(data); let new_login = new loginUserModel(data);
@ -233,9 +180,64 @@ router.post('/daftar1', async (req, res) => {
await new_kurir.save(); await new_kurir.save();
await new_login.save(); await new_login.save();
// responsenya = new_kurir; // responsenya = new_kurir;
} else if (data.role == 'pengirim') {
let isExist = await pengirimModel.findOne({ nik: data.no_telp });
// console.log(isExist.status + "ini adalag evaluasi");
// console.log("ini untuk no_telpon")
if (isExist) {
let message = (isExist.status == 'Evaluasi') ? 'No Telpon ini telah terdaftar sebelumnya dan sekarang dalam evaluasi tim kami.\n Jika anda pemilik no telpon ini, Tim kami akan mengirim ke email yang anda daftarkan sebelumnya untuk konfirmasi pendaftaran' : 'No Telpon Sudah Terdaftar dan sudah diaktifkan';
res.status(400).send({
status: false,
message: message,
focus: 'no_telp'
});
return;
}
let isExist2 = await pengirimModel.findOne({ email: data.email });
// console.log(isExist2)
// console.log("ini untuk email")
if (isExist2) {
let message = (isExist2.status == 'Evaluasi') ? 'Email ini telah terdaftar sebelumnya dan sekarang dalam evaluasi tim kami.\nTim kami akan mengirim ke email ini yang anda daftarkan sebelumnya untuk konfirmasi pendaftaran' : 'Email Sudah Terdaftar dan sudah diaktifkan';
res.status(400).send({
status: false,
message: message,
focus: 'email'
});
return;
}
// check if req.files.photo exist
if (!req.files.photo) {
res.status(400).send({
status: false,
message: 'File tidak boleh kosong'
});
return;
}
res.send({ status: true, message: 'Anda akan mendapat notifikasi di email anda dan juga no telpon jika admin menyetujui ataupun membatalkan pendaftaran anda' });
let new_pengirim = new pengirimModel(data);
// add photo_url to new_pengirim
let id_photo = googlenya.uploadFile(new_pengirim._id + ".jpg", req.files.photo.path, pengirim_folder_id, "ini photo pengirim");
new_pengirim.photo_url = `https://drive.google.com/uc?export=view&id=${await id_photo}`
console.log(new_pengirim)
let new_login = new loginUserModel(data);
// push new_pengirim._id to new_login._idnya
new_login._idnya = new_pengirim._id;
console.log(new_login);
await new_pengirim.save();
await new_login.save();
} }

View File

@ -1243,19 +1243,7 @@
dependencies: dependencies:
"is-glob" "^4.0.1" "is-glob" "^4.0.1"
"glob@^7.1.3", "glob@^7.1.6": "glob@^7.1.3", "glob@^7.1.6", "glob@7.1.7":
"integrity" "sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q=="
"resolved" "https://registry.npmjs.org/glob/-/glob-7.2.0.tgz"
"version" "7.2.0"
dependencies:
"fs.realpath" "^1.0.0"
"inflight" "^1.0.4"
"inherits" "2"
"minimatch" "^3.0.4"
"once" "^1.3.0"
"path-is-absolute" "^1.0.0"
"glob@7.1.7":
"integrity" "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==" "integrity" "sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ=="
"resolved" "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz" "resolved" "https://registry.npmjs.org/glob/-/glob-7.1.7.tgz"
"version" "7.1.7" "version" "7.1.7"
@ -2481,19 +2469,22 @@
"resolved" "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz" "resolved" "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz"
"version" "5.7.1" "version" "5.7.1"
"semver@^6.0.0", "semver@^6.2.0", "semver@^6.3.0": "semver@^6.0.0":
"integrity" "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" "integrity" "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
"resolved" "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz" "resolved" "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz"
"version" "6.3.0" "version" "6.3.0"
"semver@^7.3.4": "semver@^6.2.0":
"integrity" "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==" "integrity" "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
"resolved" "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" "resolved" "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz"
"version" "7.3.7" "version" "6.3.0"
dependencies:
"lru-cache" "^6.0.0"
"semver@^7.3.5": "semver@^6.3.0":
"integrity" "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw=="
"resolved" "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz"
"version" "6.3.0"
"semver@^7.3.4", "semver@^7.3.5":
"integrity" "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g==" "integrity" "sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g=="
"resolved" "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz" "resolved" "https://registry.npmjs.org/semver/-/semver-7.3.7.tgz"
"version" "7.3.7" "version" "7.3.7"