refactor
This commit is contained in:
@@ -1,37 +1,9 @@
|
|||||||
const cds = require('@sap/cds')
|
const cds = require('@sap/cds')
|
||||||
|
const { queriesToUpdateDifferences } = require('./utils')
|
||||||
const { Books, ShippingAddresses } = cds.entities
|
const { Books, ShippingAddresses } = cds.entities
|
||||||
|
|
||||||
const bupaSrv = cds.connect.to('API_BUSINESS_PARTNER')
|
const bupaSrv = cds.connect.to('API_BUSINESS_PARTNER')
|
||||||
|
|
||||||
const _diff = (obj1, obj2) =>
|
|
||||||
Object.keys(obj1).reduce(
|
|
||||||
(res, curr) =>
|
|
||||||
obj1[curr] === obj2[curr] ? res : (res[curr] = obj2[curr]) && res,
|
|
||||||
{}
|
|
||||||
)
|
|
||||||
|
|
||||||
const _queriesToUpdateDifferences = (ownAddresses, remoteAddresses) =>
|
|
||||||
ownAddresses
|
|
||||||
.map(ownAddress => {
|
|
||||||
const remoteAddress = remoteAddresses.find(
|
|
||||||
address =>
|
|
||||||
address.BusinessPartner === ownAddress.BusinessPartner &&
|
|
||||||
address.AddressID === ownAddress.AddressID
|
|
||||||
)
|
|
||||||
if (remoteAddress) {
|
|
||||||
const diff = _diff(ownAddress, remoteAddress)
|
|
||||||
if (Object.keys(diff).length) {
|
|
||||||
return UPDATE(ShippingAddresses)
|
|
||||||
.set(diff)
|
|
||||||
.where({
|
|
||||||
BusinessPartner: ownAddress.BusinessPartner,
|
|
||||||
AddressID: ownAddress.AddressID
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.filter(el => el)
|
|
||||||
|
|
||||||
bupaSrv.on('Changed', 'BusinessPartner', async msg => {
|
bupaSrv.on('Changed', 'BusinessPartner', async msg => {
|
||||||
console.log('>> Message:', msg.data)
|
console.log('>> Message:', msg.data)
|
||||||
|
|
||||||
@@ -44,11 +16,12 @@ bupaSrv.on('Changed', 'BusinessPartner', async msg => {
|
|||||||
const txExt = bupaSrv.transaction(msg)
|
const txExt = bupaSrv.transaction(msg)
|
||||||
try {
|
try {
|
||||||
const remoteAddresses = await txExt.run(selectQuery)
|
const remoteAddresses = await txExt.run(selectQuery)
|
||||||
const queriesToUpdateDifferences = _queriesToUpdateDifferences(
|
const updateQueries = queriesToUpdateDifferences(
|
||||||
|
ShippingAddresses,
|
||||||
ownAddresses,
|
ownAddresses,
|
||||||
remoteAddresses
|
remoteAddresses
|
||||||
)
|
)
|
||||||
await tx.run(queriesToUpdateDifferences)
|
await tx.run(updateQueries)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error(e)
|
console.error(e)
|
||||||
}
|
}
|
||||||
@@ -59,7 +32,9 @@ async function _readAddresses (req) {
|
|||||||
console.log('Addresses', ShippingAddresses)
|
console.log('Addresses', ShippingAddresses)
|
||||||
const BusinessPartner = req.user.id
|
const BusinessPartner = req.user.id
|
||||||
const txExt = bupaSrv.transaction(req)
|
const txExt = bupaSrv.transaction(req)
|
||||||
const selectQuery = req.query.from(ShippingAddresses).where({ BusinessPartner })
|
const selectQuery = req.query
|
||||||
|
.from(ShippingAddresses)
|
||||||
|
.where({ BusinessPartner })
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return txExt.run(selectQuery)
|
return txExt.run(selectQuery)
|
||||||
|
|||||||
31
packages/bookshop/srv/utils.js
Normal file
31
packages/bookshop/srv/utils.js
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
const diff = (obj1, obj2) =>
|
||||||
|
Object.keys(obj1).reduce(
|
||||||
|
(res, curr) =>
|
||||||
|
obj1[curr] === obj2[curr] ? res : (res[curr] = obj2[curr]) && res,
|
||||||
|
{}
|
||||||
|
)
|
||||||
|
|
||||||
|
const queriesToUpdateDifferences = (entity, ownEntries, otherEntries) =>
|
||||||
|
ownEntries
|
||||||
|
.map(ownEntry => {
|
||||||
|
const remoteAddress = otherEntries.find(otherEntry =>
|
||||||
|
Object.keys(entity.keys).reduce(
|
||||||
|
(res, curr) => res && otherEntry[curr] === ownEntry[curr],
|
||||||
|
true
|
||||||
|
)
|
||||||
|
)
|
||||||
|
if (remoteAddress) {
|
||||||
|
const diff = _diff(ownEntry, remoteAddress)
|
||||||
|
if (Object.keys(diff).length) {
|
||||||
|
return UPDATE(entity)
|
||||||
|
.set(diff)
|
||||||
|
.where({
|
||||||
|
BusinessPartner: ownEntry.BusinessPartner,
|
||||||
|
AddressID: ownEntry.AddressID
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.filter(el => el)
|
||||||
|
|
||||||
|
module.exports = { diff, queriesToUpdateDifferences }
|
||||||
Reference in New Issue
Block a user