/// /// Copyright © 2016-2019 The Thingsboard Authors /// /// Licensed 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. /// import {Inject, Injectable} from '@angular/core'; import { defaultHttpOptions, defaultHttpOptionsFromConfig, RequestConfig } from './http-utils'; import { Observable, ReplaySubject, Subject } from 'rxjs/index'; import {HttpClient} from '@angular/common/http'; import {PageLink} from '@shared/models/page/page-link'; import {PageData} from '@shared/models/page/page-data'; import {Dashboard, DashboardInfo} from '@shared/models/dashboard.models'; import {WINDOW} from '@core/services/window.service'; import { ActivationEnd, NavigationEnd, Router } from '@angular/router'; import { filter, map, publishReplay, refCount } from 'rxjs/operators'; @Injectable({ providedIn: 'root' }) export class DashboardService { stDiffObservable: Observable; currentUrl: string; constructor( private http: HttpClient, private router: Router, @Inject(WINDOW) private window: Window ) { this.currentUrl = this.router.url.split('?')[0]; this.router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe( () => { const newUrl = this.router.url.split('?')[0]; if (this.currentUrl !== newUrl) { this.stDiffObservable = null; this.currentUrl = newUrl; } } ); } public getTenantDashboards(pageLink: PageLink, config?: RequestConfig): Observable> { return this.http.get>(`/api/tenant/dashboards${pageLink.toQuery()}`, defaultHttpOptionsFromConfig(config)); } public getTenantDashboardsByTenantId(tenantId: string, pageLink: PageLink, config?: RequestConfig): Observable> { return this.http.get>(`/api/tenant/${tenantId}/dashboards${pageLink.toQuery()}`, defaultHttpOptionsFromConfig(config)); } public getCustomerDashboards(customerId: string, pageLink: PageLink, config?: RequestConfig): Observable> { return this.http.get>(`/api/customer/${customerId}/dashboards${pageLink.toQuery()}`, defaultHttpOptionsFromConfig(config)); } public getDashboard(dashboardId: string, config?: RequestConfig): Observable { return this.http.get(`/api/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config)); } public getDashboardInfo(dashboardId: string, config?: RequestConfig): Observable { return this.http.get(`/api/dashboard/info/${dashboardId}`, defaultHttpOptionsFromConfig(config)); } public saveDashboard(dashboard: Dashboard, config?: RequestConfig): Observable { return this.http.post('/api/dashboard', dashboard, defaultHttpOptionsFromConfig(config)); } public deleteDashboard(dashboardId: string, config?: RequestConfig) { return this.http.delete(`/api/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config)); } public assignDashboardToCustomer(customerId: string, dashboardId: string, config?: RequestConfig): Observable { return this.http.post(`/api/customer/${customerId}/dashboard/${dashboardId}`, null, defaultHttpOptionsFromConfig(config)); } public unassignDashboardFromCustomer(customerId: string, dashboardId: string, config?: RequestConfig) { return this.http.delete(`/api/customer/${customerId}/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config)); } public makeDashboardPublic(dashboardId: string, config?: RequestConfig): Observable { return this.http.post(`/api/customer/public/dashboard/${dashboardId}`, null, defaultHttpOptionsFromConfig(config)); } public makeDashboardPrivate(dashboardId: string, config?: RequestConfig): Observable { return this.http.delete(`/api/customer/public/dashboard/${dashboardId}`, defaultHttpOptionsFromConfig(config)); } public updateDashboardCustomers(dashboardId: string, customerIds: Array, config?: RequestConfig): Observable { return this.http.post(`/api/dashboard/${dashboardId}/customers`, customerIds, defaultHttpOptionsFromConfig(config)); } public addDashboardCustomers(dashboardId: string, customerIds: Array, config?: RequestConfig): Observable { return this.http.post(`/api/dashboard/${dashboardId}/customers/add`, customerIds, defaultHttpOptionsFromConfig(config)); } public removeDashboardCustomers(dashboardId: string, customerIds: Array, config?: RequestConfig): Observable { return this.http.post(`/api/dashboard/${dashboardId}/customers/remove`, customerIds, defaultHttpOptionsFromConfig(config)); } public getPublicDashboardLink(dashboard: DashboardInfo): string | null { if (dashboard && dashboard.assignedCustomers && dashboard.assignedCustomers.length > 0) { const publicCustomers = dashboard.assignedCustomers .filter(customerInfo => customerInfo.public); if (publicCustomers.length > 0) { const publicCustomerId = publicCustomers[0].customerId.id; let url = this.window.location.protocol + '//' + this.window.location.hostname; const port = this.window.location.port; if (port !== '80' && port !== '443') { url += ':' + port; } url += `/dashboard/${dashboard.id.id}?publicId=${publicCustomerId}`; return url; } } return null; } public getServerTimeDiff(): Observable { if (!this.stDiffObservable) { const url = '/api/dashboard/serverTime'; const ct1 = Date.now(); this.stDiffObservable = this.http.get(url, defaultHttpOptions(true)).pipe( map((st) => { const ct2 = Date.now(); const stDiff = Math.ceil(st - (ct1 + ct2) / 2); return stDiff; }), publishReplay(1), refCount() ); } return this.stDiffObservable; } }