This commit is contained in:
D065023
2019-12-16 21:02:57 +01:00
parent dfea19334d
commit 3e725bcc26
2 changed files with 38 additions and 32 deletions

View File

@@ -1,37 +1,9 @@
const cds = require('@sap/cds')
const { queriesToUpdateDifferences } = require('./utils')
const { Books, ShippingAddresses } = cds.entities
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 => {
console.log('>> Message:', msg.data)
@@ -44,11 +16,12 @@ bupaSrv.on('Changed', 'BusinessPartner', async msg => {
const txExt = bupaSrv.transaction(msg)
try {
const remoteAddresses = await txExt.run(selectQuery)
const queriesToUpdateDifferences = _queriesToUpdateDifferences(
const updateQueries = queriesToUpdateDifferences(
ShippingAddresses,
ownAddresses,
remoteAddresses
)
await tx.run(queriesToUpdateDifferences)
await tx.run(updateQueries)
} catch (e) {
console.error(e)
}
@@ -59,7 +32,9 @@ async function _readAddresses (req) {
console.log('Addresses', ShippingAddresses)
const BusinessPartner = req.user.id
const txExt = bupaSrv.transaction(req)
const selectQuery = req.query.from(ShippingAddresses).where({ BusinessPartner })
const selectQuery = req.query
.from(ShippingAddresses)
.where({ BusinessPartner })
try {
return txExt.run(selectQuery)

View 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 }