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 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)

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 }