36876233df6b8785117c283441b74e34f42dd7df
[ccsdk/cds.git] /
1 /*
2 ============LICENSE_START==========================================
3 ===================================================================
4 Copyright (C) 2018 IBM Intellectual Property. All rights reserved.
5 ===================================================================
6
7 Unless otherwise specified, all software contained herein is licensed
8 under the Apache License, Version 2.0 (the License);
9 you may not use this software except in compliance with the License.
10 You may obtain a copy of the License at
11
12     http://www.apache.org/licenses/LICENSE-2.0
13
14 Unless required by applicable law or agreed to in writing, software
15 distributed under the License is distributed on an "AS IS" BASIS,
16 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 See the License for the specific language governing permissions and
18 limitations under the License.
19 ============LICENSE_END============================================
20 */
21
22 import { Component, OnInit, EventEmitter, Output, ViewChild } from '@angular/core';
23 import { Store } from '@ngrx/store';
24 import * as JSZip from 'jszip';
25 import { Observable } from 'rxjs';
26
27 import { IBlueprint } from '../../../../common/core/store/models/blueprint.model';
28 import { IBlueprintState } from '../../../../common/core/store/models/blueprintState.model';
29 import { IAppState } from '../../../../common/core/store/state/app.state';
30 import { LoadBlueprintSuccess, SET_BLUEPRINT_STATE, SetBlueprintState } from '../../../../common/core/store/actions/blueprint.action';
31 import { json } from 'd3';
32
33 @Component({
34   selector: 'app-search-template',
35   templateUrl: './search-template.component.html',
36   styleUrls: ['./search-template.component.scss']
37 })
38 export class SearchTemplateComponent implements OnInit {
39   file: File;
40   localBluePrintData: IBlueprint;
41   fileText: object[];
42   blueprintState: IBlueprintState;
43   bpState: Observable<IBlueprintState>;
44   validfile: boolean = false;
45
46   @ViewChild('fileInput') fileInput;
47   result: string = '';
48
49   private paths = [];
50   private tree;
51   private zipFile: JSZip = new JSZip();
52   private fileObject: any;
53   private activationBlueprint: any;
54   private tocsaMetadaData: any;
55   private blueprintName: string;
56
57   constructor(private store: Store<IAppState>) { }
58
59   ngOnInit() {
60   }
61
62   fileChanged(e: any) {
63     this.paths = [];
64     this.file = e.target.files[0];
65     this.zipFile.files = {};
66     this.zipFile.loadAsync(this.file)
67       .then((zip) => {
68         if(zip) {            
69           this.buildFileViewData(zip);
70         }
71       });
72   }
73
74   updateBlueprintState() {
75     let data: IBlueprint = this.activationBlueprint ? JSON.parse(this.activationBlueprint.toString()) : this.activationBlueprint;
76     let blueprintState = {
77       blueprint: data,
78       name: this.blueprintName,
79       files: this.tree,
80       filesData: this.paths
81     }
82     this.store.dispatch(new SetBlueprintState(blueprintState))
83     // this.store.dispatch(new LoadBlueprintSuccess(data));
84   }
85
86   async buildFileViewData(zip) {
87     this.validfile = false;
88     this.paths = [];
89     for (var file in zip.files) {
90       this.fileObject = {
91         name: zip.files[file].name,
92         data: ''
93       };
94       const value = <any>await  zip.files[file].async('string');
95       this.fileObject.data = value;
96       this.paths.push(this.fileObject); 
97     }
98
99     if(this.paths) {
100       this.paths.forEach(path =>{
101         if(path.name.includes("TOSCA.meta")) {
102           this.validfile = true
103         }
104       });
105     } else {
106       alert('Please update proper file');
107     }
108
109     if(this.validfile) {      
110       this.fetchTOSACAMetadata();
111       this.tree = this.arrangeTreeData(this.paths);
112     } else {
113       alert('Please update proper file with TOSCA metadata');
114     }
115   }
116
117   arrangeTreeData(paths) {
118     const tree = [];
119
120     paths.forEach((path) => {
121
122       const pathParts = path.name.split('/');
123       // pathParts.shift();
124       let currentLevel = tree;
125
126       pathParts.forEach((part) => {
127         const existingPath = currentLevel.filter(level => level.name === part);
128
129         if (existingPath.length > 0) {
130           currentLevel = existingPath[0].children;
131         } else {
132           const newPart = {
133             name: part,
134             children: [],
135             data: path.data,
136             path : path.name
137           };
138           if(part.trim() == this.blueprintName.trim()) { 
139             this.activationBlueprint = path.data; 
140             newPart.data = JSON.parse(this.activationBlueprint.toString());            
141             console.log('newpart', newPart);
142           }
143           if(newPart.name !== '') {            
144               currentLevel.push(newPart);
145               currentLevel = newPart.children;
146           }
147         }
148       });
149     });
150     console.log('tree', tree);
151     return tree;
152   }
153
154   fetchTOSACAMetadata() {
155     let toscaData = {};
156     this.paths.forEach(file =>{
157       if(file.name.includes('TOSCA.meta')) {
158         let keys = file.data.split("\n");
159         keys.forEach((key)=>{
160           let propertyData = key.split(':');
161           toscaData[propertyData[0]] = propertyData[1];
162         });
163       }
164     });
165     this.blueprintName = (((toscaData['Entry-Definitions']).split('/'))[1]).toString();;
166     console.log(toscaData);
167   }
168 }