Skip to content

Commit

Permalink
refactor: used new decorate function for distributed services in KDK
Browse files Browse the repository at this point in the history
  • Loading branch information
claustres committed Dec 23, 2024
1 parent 0657739 commit 429d8ef
Showing 1 changed file with 6 additions and 15 deletions.
21 changes: 6 additions & 15 deletions api/src/services/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { fileURLToPath } from 'url'
import moment from 'moment'
import pointOnFeature from '@turf/point-on-feature'
import makeDebug from 'debug'
import kCore, { createObjectID, permissions } from '@kalisio/kdk/core.api.js'
import kCore, { createObjectID, permissions, decorateDistributedService } from '@kalisio/kdk/core.api.js'
import kMap, {
createFeaturesService, removeFeaturesService,
createCatalogService, removeCatalogService,
Expand Down Expand Up @@ -355,22 +355,13 @@ export default async function () {
// Make remote services compliant with our internal app services so that permissions can be used
if (service.key === 'kano' || service.key === 'weacast') {
debug('Configuring remote service', service)
// Remote service are registered according to their path, ie with API prefix (but without trailing /)
const remoteService = app.service(service.path)
// Get name from service path without api prefix
const name = service.path.replace(app.get('apiPath').substring(1) + '/', '')
remoteService.name = name
// As remote services have no context, from the internal point of view path = name
// Unfortunately this property is already set and used by feathers-distributed and should not be altered
// remoteService.path = name
remoteService.app = app
remoteService.getPath = function (withApiPrefix) { return (withApiPrefix ? app.get('apiPath') + '/' + name : name) }
decorateDistributedService.call(app, service)
// Register default permissions for it
debug('Registering permissions for remote service ', name)
debug('Registering permissions for remote service ', service.name)
permissions.defineAbilities.registerHook((subject, can, cannot) => {
can('service', name)
can('read', name)
if (name === 'probes') can('create', name)
can('service', service.name)
can('read', service.name)
if (service.name === 'probes') can('create', service.name)
})
// We then need to update abilities cache
const authorisationService = app.getService('authorisations')
Expand Down

0 comments on commit 429d8ef

Please sign in to comment.