Я настраиваю Контроль доступа для углового приложения и смоделировал мой объект User следующим образом: -User --firstName --phoneNumber --posts [] <--- Строковый массив идентификаторов записей </p>
getPosts(): Observable<any[]> {
return this.postsCollection.snapshotChanges().pipe(
map((actions) => {
return actions.map((a) => {
const data = a.payload.doc.data();
const data2 = { id: a.payload.doc.id, ...data};
this.hasPostAccess(data2);
return { id: a.payload.doc.id, ...data};
});
})
);
}
private hasPostAccess(data: any) {
const inspect = obj => {
for (const prop in obj) {
if (obj.hasOwnProperty(prop)) {
// console.log(`${prop}: ${obj[prop]}`);
if (prop === 'id') {
console.log(obj[prop]);
const PostId = obj[prop];
const currentUser = JSON.stringify(localStorage.getItem('user'));
if (currentUser.search(PostId) === -1) {
console.log('Denied: ' + PostId);
} else {
console.log('Allowed: ' + PostId);
}
console.log('Current USER: ' + JSON.stringify(currentUser));
// if (currentUser(PostId) > -1) {
// console.log('Allowed: ' + PostId);
// } else {
// console.log('Denied: ' + PostId);
// }
}
}
}
};
inspect(data);
}
Я хочу показать все сообщения, которые принадлежат пользователю.Поэтому, когда я подписываюсь на наблюдаемую getPosts, это должно фильтровать посты и возвращать только те идентификаторы постов, которые хранятся в массиве постов пользователя.