2018-07-06 12:33:16 +02:00
|
|
|
import { Injectable } from '@angular/core';
|
|
|
|
import { Http, Response, Headers, RequestOptions } from '@angular/http';
|
|
|
|
import { Observable } from 'rxjs/Rx';
|
|
|
|
import {COOKIE} from "../../login/utils/helper.class"
|
|
|
|
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class SubscribeService {
|
|
|
|
|
|
|
|
constructor(private http:Http) {
|
|
|
|
}
|
|
|
|
getCommunitySubscribers(pid:string, url:string){
|
|
|
|
return this.http.get(url+"/community/"+pid+"/subscribers")
|
2019-02-14 11:15:44 +01:00
|
|
|
.map(res => <any> res.json());
|
2018-07-06 12:33:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
isSubscribedToCommunity(pid:string, email:string, url:string){
|
|
|
|
return this.http.get(url+"/community/"+pid+"/subscribers")
|
|
|
|
.map(res => ((<any>res =="")?{}:<any> res.json()))
|
|
|
|
|
|
|
|
.map(res => {
|
2018-10-01 14:46:21 +02:00
|
|
|
if(res.status && res.status != 200) {
|
|
|
|
return null;
|
|
|
|
}
|
2018-07-06 12:33:16 +02:00
|
|
|
if(res.subscribers && res.subscribers != null){
|
|
|
|
|
|
|
|
for(var i =0; i< res.subscribers.length; i++ ){
|
|
|
|
if(res.subscribers[i]!=null && res.subscribers[i].email == email){
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
|
2019-02-14 11:15:44 +01:00
|
|
|
});
|
2018-07-06 12:33:16 +02:00
|
|
|
}
|
|
|
|
subscribeToCommunity(pid:string, email:string, url:string){
|
|
|
|
var subscriber = {"email":email};
|
|
|
|
return this.http.post(url+"/community/"+pid+"/subscribers", JSON.stringify(subscriber), this.getAuthOptionsWithBody())
|
2019-02-14 11:15:44 +01:00
|
|
|
.map(res => <any> res.json());
|
2018-07-06 12:33:16 +02:00
|
|
|
}
|
|
|
|
unSubscribeToCommunity(pid:string, email:string, url:string){
|
|
|
|
|
|
|
|
return this.http.post(url+"/community/"+pid+"/subscribers/delete", JSON.stringify([email]), this.getAuthOptionsWithBody())
|
2019-02-14 11:15:44 +01:00
|
|
|
.map(res => <any> res.json());
|
2018-07-06 12:33:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public getAuthOptionsWithBody():RequestOptions{
|
|
|
|
let headers = new Headers();
|
|
|
|
headers.append('Content-Type', 'application/json');
|
|
|
|
headers.append('X-XSRF-TOKEN', COOKIE.getCookie(COOKIE.cookieName_id));
|
|
|
|
let options = new RequestOptions({ headers: headers, withCredentials:true });
|
|
|
|
return options;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|