aboutsummaryrefslogtreecommitdiffstats
path: root/catalog-ui/src/app/services/onboarding-service.ts
diff options
context:
space:
mode:
authorMichael Lando <ml636r@att.com>2017-06-09 03:19:04 +0300
committerMichael Lando <ml636r@att.com>2017-06-09 03:19:04 +0300
commited64b5edff15e702493df21aa3230b81593e6133 (patch)
treea4cb01fdaccc34930a8db403a3097c0d1e40914b /catalog-ui/src/app/services/onboarding-service.ts
parent280f8015d06af1f41a3ef12e8300801c7a5e0d54 (diff)
[SDC-29] catalog 1707 rebase commit.
Change-Id: I43c3dc5cf44abf5da817649bc738938a3e8388c1 Signed-off-by: Michael Lando <ml636r@att.com>
Diffstat (limited to 'catalog-ui/src/app/services/onboarding-service.ts')
-rw-r--r--catalog-ui/src/app/services/onboarding-service.ts82
1 files changed, 82 insertions, 0 deletions
diff --git a/catalog-ui/src/app/services/onboarding-service.ts b/catalog-ui/src/app/services/onboarding-service.ts
new file mode 100644
index 0000000000..8b93b18ca9
--- /dev/null
+++ b/catalog-ui/src/app/services/onboarding-service.ts
@@ -0,0 +1,82 @@
+'use strict';
+import {Component, IComponent} from "../models/components/component";
+import {ICsarComponent} from "../models/csar-component";
+import {IAppConfigurtaion, IApi} from "../models/app-config";
+import {IFileDownload} from "../models/file-download";
+import {Resource} from "../models/components/resource";
+import {ComponentFactory} from "../utils/component-factory";
+
+interface IOnboardingService {
+ getOnboardingComponents():ng.IPromise<Array<IComponent>>;
+ getComponentFromCsarUuid(csarUuid:string):ng.IPromise<Component>;
+ downloadOnboardingCsar(packageId:string):ng.IPromise<IFileDownload>;
+}
+
+export class OnboardingService implements IOnboardingService {
+
+ static '$inject' = ['$http', '$q', 'sdcConfig', 'ComponentFactory'];
+ private api:IApi;
+
+ constructor(private $http:ng.IHttpService,
+ private $q:ng.IQService,
+ private sdcConfig:IAppConfigurtaion,
+ private ComponentFactory:ComponentFactory) {
+ this.api = sdcConfig.api;
+ }
+
+ getOnboardingComponents = ():ng.IPromise<Array<IComponent>> => {
+ let defer = this.$q.defer<Array<IComponent>>();
+ this.$http.get(this.api.GET_onboarding)
+ .then((response:any) => {
+ let onboardingComponents:Array<ICsarComponent> = response.data.results;
+ let componentsList:Array<IComponent> = new Array();
+
+ onboardingComponents.forEach((obc:ICsarComponent) => {
+ let component:Component = this.ComponentFactory.createFromCsarComponent(obc);
+ componentsList.push(component);
+ });
+
+ defer.resolve(componentsList);
+ },(response) => {
+ defer.reject(response);
+ });
+
+ return defer.promise;
+ };
+
+ downloadOnboardingCsar = (packageId:string):ng.IPromise<IFileDownload> => {
+ let defer = this.$q.defer();
+ this.$http({
+ url: this.api.GET_onboarding + "/" + packageId,
+ method: "get",
+ responseType: "blob"
+ })
+ .then((response:any) => {
+ defer.resolve(response.data);
+ }, (err) => {
+ defer.reject(err);
+ });
+
+ return defer.promise;
+ };
+
+ getComponentFromCsarUuid = (csarUuid:string):ng.IPromise<Component> => {
+ let defer = this.$q.defer<Component>();
+ this.$http.get(this.api.root + this.api.GET_component_from_csar_uuid.replace(':csar_uuid', csarUuid))
+ .then((response:any) => {
+ let component:Resource;
+ // If the status is 400, this means that the component not found.
+ // I do not want to return error from server, because a popup will appear in client with the error.
+ // So returning success (200) with status 400.
+ if (response.data.status !== 400) {
+ component = new Resource(null, this.$q, <Resource>response.data);
+ }
+ defer.resolve(component);
+ },(response) => {
+ defer.reject(response.data);
+ });
+
+ return defer.promise;
+ };
+
+}