123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 |
- /**
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- var App = require('app');
- App.dataSetMapper = App.QuickDataMapper.create({
- model: App.Dataset,
- Jobs_model: App.DataSetJob,
- config: {
- id: 'id', // approach 2 : to be calculated (TBC1)
- name: 'Feeds.name', // from json
- status: 'Feeds.status', // from json
- source_cluster_name: 'Feeds.clusters.cluster[0].name', // approach1 : from json
- $target_cluster: 'none', // will be loaded outside parser ( TBC2 ),
- source_dir: 'Feeds.locations.location.path',
- $schedule_id: 'none', // will be loaded outside parser
- dataset_jobs: 'dataset_jobs', // TBC3 ( set of ids will be added )
- // all below are unknown at present and may be blank
- last_failed_date: 'last_failed_date', // TBC4
- last_succeeded_date: 'last_succeeded_date', // TBC5
- last_duration: 'last_duration', // TBC6
- avg_data: 'avg_data', // TBC7
- created_date: 'created_date', // TBC8
- target_dir: 'target_dir'
- },
- jobs_config: {
- $dataset_id: 'none', // will be loaded outside parser
- id: 'Instances.id',
- status : 'Instances.status',
- start_date: 'start_date',
- end_date: 'end_date',
- duration: 'duration'
- //data: 'Instances.details'
- },
- schedule_config: {
- $dataset_id: 'none', // will be loaded outside parser
- id: 'id',
- start_date : 'start_date',
- end_date : 'end_date',
- start_time : 'start_time',
- end_time : 'end_time',
- timezone : 'timezone',
- frequency : 'frequency'
- },
- loadSchedule: function (datasetItemFromJson) {
- App.store.load(App.Dataset.Schedule, this.parseSchedule(datasetItemFromJson));
- },
- parseSchedule: function(datasetItemFromJson) {
- var schedule = {};
- schedule.id = datasetItemFromJson.id;
- var source_cluster = datasetItemFromJson.Feeds.clusters.cluster.findProperty("type", "source");
- var start_date = new Date(source_cluster.validity.start);
- var end_date = new Date(source_cluster.validity.end);
- var d = new Date();
- var start_mm = start_date.getMonth() + 1; // In future may consider using getUTCMonth()
- var start_dd = start_date.getDay();
- var start_yyyy = start_date.getFullYear();
- var end_mm = end_date.getMonth() + 1;
- var end_dd = end_date.getDay();
- var end_yyyy = end_date.getFullYear();
- schedule.start_date = start_mm + "/" + start_dd + "/" + start_yyyy;
- schedule.end_date = end_mm + "/" + end_dd + "/" + end_yyyy;
- var start_hh = start_date.getHours();
- var start_mi = start_date.getMinutes();
- var start_ampm = (start_hh < 12 ? 'AM' : 'PM');
- var end_hh = end_date.getHours();
- var end_mi = end_date.getMinutes();
- var end_ampm = (end_hh < 12 ? 'AM' : 'PM');
- if (start_hh) {
- start_hh %= 12;
- }
- if (end_hh) {
- end_hh %= 12;
- }
- schedule.start_time = start_hh + ":" + start_mi + ":" + start_ampm;
- schedule.end_time = end_hh + ":" + end_mi + ":" + end_ampm;
- schedule.frequency = datasetItemFromJson.Feeds.frequency;
- schedule.timezone = datasetItemFromJson.Feeds.timezone;
- schedule.dataset_id = datasetItemFromJson.id;
- return schedule;
- },
- map: function (json) {
- if (!this.get('model')) {
- return;
- }
- if (json && json.items && json.items.length > 0) {
- var dataset_results = [];
- json.items.forEach(function (item) {
- try {
- // TBC1
- item.id = this.getId(item.Feeds.name);
- // TBC3
- item.dataset_jobs = [];
- var last_failed_date = null;
- var last_succeeded_date = null;
- var last_end_date = null;
- item.instances.forEach(function (job) {
- var end_date = new Date(job.Instances.end);
- if (!last_end_date) {
- last_end_date = end_date;
- item.last_job = job;
- }
- else if (end_date > last_end_date) {
- last_end_date = end_date;
- item.last_job = job;
- }
- if (job.Instances.status === 'FAILED') {
- if (last_failed_date == null || last_failed_date < end_date) {
- item.last_failed_date = end_date.getTime();
- last_failed_date = end_date;
- }
- }
- else if (job.Instances.status === 'SUCCESSFUL') {
- if (last_succeeded_date == null || last_succeeded_date < end_date) {
- item.last_succeeded_date = end_date.getTime();
- last_succeeded_date = end_date;
- }
- }
- item.dataset_jobs.push(job.Instances.id);
- });
- // calculate last_duration
- var last_end_date = new Date(item.last_job.Instances.end);
- var last_start_date = new Date(item.last_job.Instances.start);
- item.last_duration = last_end_date - last_start_date;
- item.avg_data = '';
- item.created_date = '';
- item.target_dir = '';
- var newitem = this.parseIt(item, this.config);
- // TBC2 - but shd be loaded after parsing
- var target_cluster_name = (item.Feeds.clusters.cluster.findProperty("type", "target")).name;
- var target_cluster_id = (item.Feeds.clusters.cluster.findProperty("type", "target")).name;
- newitem.target_cluster_id = this.getId(target_cluster_id);
- newitem.schedule_id = newitem.id;
- this.loadSchedule(item);
- dataset_results.push(newitem);
- } catch (ex) {
- console.debug('Exception occured : ' + ex);
- }
- }, this);
- console.debug('Before load: App.Dataset.find().content : ' + App.Dataset.find().content);
- App.store.loadMany(this.get('model'), dataset_results);
- console.debug('After load: App.Dataset.find().content : ' + App.Dataset.find().content);
- try {
- // Child records
- var dataset_job_results = [];
- json.items.forEach(function (item) {
- item.instances.forEach(function (instance) {
- instance.Instances.start = new Date(instance.Instances.start); // neeed to be calulated end -start
- instance.Instances.end = new Date(instance.Instances.end); // neeed to be calulated end -start
- instance.duration = instance.Instances.end - instance.Instances.start;
- instance.start_date = instance.Instances.start;
- instance.end_date = instance.Instances.end;
- var result = this.parseIt(instance, this.jobs_config);
- result.dataset_id = item.id;
- dataset_job_results.push(result);
- }, this)
- }, this);
- console.debug('Before load: App.DataSetJob.find().content : ' + App.DataSetJob.find().content);
- App.store.loadMany(this.get('Jobs_model'), dataset_job_results);
- console.debug('After load: App.DataSetJob.find().content : ' + App.DataSetJob.find().content);
- }
- catch (ex) {
- console.debug('Exception occured : ' + ex);
- }
- }
- },
- getId: function(n) {
- var re = new RegExp(" ", "g");
- return n.replace(re, "_");
- }
- });
|