Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 | 1x 1x 1x 1x 1x 1x 1x 138x 138x 1x 156x 156x 156x 156x 156x 156x 156x 156x | /*
* Canopy Match Maker
*
* Copyright 2015 Raising the Floor - International
*
* Licensed under the New BSD license. You may not use this file except in
* compliance with this License.
*
* The research leading to these results has received funding from the European Union's
* Seventh Framework Programme (FP7/2007-2013)
* under grant agreement no. 289016.
*
* You may obtain a copy of the License at
* https://github.com/GPII/universal/blob/master/LICENSE.txt
*/
/* global require */
"use strict";
var fluid = fluid || require("infusion"),
gpii = fluid.registerNamespace("gpii");
fluid.require("kettle", require);
fluid.registerNamespace("gpii.canopyMatchMaker");
fluid.defaults("gpii.canopyMatchMaker", {
gradeNames: ["kettle.app"],
components: {
ontologyHandler: {
"type": "gpii.ontologyHandler"
}
},
requestHandlers: {
matchPost: {
route: "/match",
method: "post",
type: "gpii.canopyMatchMaker.matchPost.handler"
}
},
invokers: {
match: {
funcName: "gpii.canopyMatchMaker.match",
args: [ "{ontologyHandler}", "{arguments}.0", "{that}.disposeStrategy"]
},
disposeStrategy: {
funcName: "gpii.canopyMatchMaker.utils.disposeStrategy",
args: [ "{arguments}.0", "{arguments}.1", "{arguments}.2", "{arguments}.3"]
// leaves, solrecs, augmented MM input payload, ontologyMetadata
}
}
});
fluid.defaults("gpii.canopyMatchMaker.matchPost.handler", {
gradeNames: ["kettle.request.http"],
invokers: {
handleRequest: {
funcName: "gpii.canopyMatchMaker.matchPost.handleRequest",
args: ["{gpii.canopyMatchMaker}", "{request}", "{request}.req.body"]
}
}
});
/**
* Initial function to be called when the user hits the /match URL. Simply calls the
* gpii.canopyMatchMaker.match function and fires the 'onSuccess' event with the result
*/
gpii.canopyMatchMaker.matchPost.handleRequest = function (canopyMatchMaker, request, body) {
var matchedSolutions = canopyMatchMaker.match(body);
request.events.onSuccess.fire(matchedSolutions);
};
/*
* Main function of the canopy matchmaker. Ensures that the inferred common terms are taken
* into account and that the preferences are stored in a hierarchical format, needed by
* the canopy MM, and then runs the frameworks' 'disposeSolutions' function with the
* canopyMatchMaker.disposeStrategy strategy. The correct output format is ensured by the
* buildReturnPayload function of the MM framework.
*/
gpii.canopyMatchMaker.match = function (ontologyHandler, payload, disposeStrategy) {
// augment payload with inferred common terms
payload.preferences = gpii.matchMakerFramework.utils.addInferredCommonTermsToPreferences(payload.preferences, payload.inferredCommonTerms);
// augment payload with information about the solution types
var appTransformSpec = gpii.ontologyHandler.getTransformSpec(ontologyHandler.ontologyTransformSpecs, "flat", "apptology");
gpii.matchMakerFramework.utils.addSolutionTypeInformation(payload, appTransformSpec);
// Add hierarchical ISO24751 version preferences
payload.hierarchicalPrefs = ontologyHandler.prefsToOntology(payload.preferences, "flat", "ISO24751");
var transformSpec = gpii.ontologyHandler.getTransformSpec(ontologyHandler.ontologyTransformSpecs, "flat", "ISO24751");
var ontologyMetadata = ontologyHandler.ontologyMetadata.ISO24751;
var disposed = gpii.matchMakerFramework.utils.disposeSolutions(payload, disposeStrategy, transformSpec, ontologyMetadata);
return gpii.matchMakerFramework.utils.buildReturnPayload(payload, disposed);
};
|