* Copyright (c) 2025 Huawei Device Co., Ltd.
* 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 { cloud, CloudDBCollection, CloudDBZoneQuery } from '@hw-agconnect/cloud-server';
import { collect as Collect } from './model/collect';
import { resource as Resource } from './model/resource';
import { ResourceResp } from './model/ResourceResp';
import { topic as Topic } from './model/topic';
import { user_like as UserLike } from './model/user_like';
const ZONE_NAME = 'HMOSWorld';
export class DatabaseHelper {
logger;
colCollect: CloudDBCollection<Collect>;
colResource: CloudDBCollection<Resource>;
colTopic: CloudDBCollection<Topic>;
colUserLike: CloudDBCollection<UserLike>;
constructor(logger) {
this.logger = logger;
this.colCollect = cloud.database({ zoneName: ZONE_NAME }).collection(Collect);
this.colResource = cloud.database({ zoneName: ZONE_NAME }).collection(Resource);
this.colTopic = cloud.database({ zoneName: ZONE_NAME }).collection(Topic);
this.colUserLike = cloud.database({ zoneName: ZONE_NAME }).collection(UserLike);
}
async queryResource(userId: string): Promise<ResourceResp[]> {
const resList: ResourceResp[] = [];
try {
const collectQuery: CloudDBZoneQuery<Collect> =
this.colCollect.query().orderByDesc("collect_time").equalTo('user_id', userId);
const collectData: Collect[] = await collectQuery.get();
this.logger.info(`[collect] collectQuery success collectData=>', ${JSON.stringify(collectData)}`);
if (collectData.length <= 0) {
return resList;
}
const rids: string[] = [];
for (let i = 0; i < collectData.length; i++) {
const resId: string = collectData[i].getResource_id();
if (resId && resId.trim().length > 0) {
rids.push(resId);
}
}
const likedIds: string[] = await this.queryLikedIds(userId);
const collectedIds: string[] = await this.queryCollectedIds(userId);
const resQuery: CloudDBZoneQuery<Resource> = this.colResource.query().in('id', rids);
const resData: Resource[] = await resQuery.get();
if (resData.length > 0) {
resData.sort(function (a, b) {
return rids.indexOf(a.getId()) - rids.indexOf(b.getId());
});
const topics: Topic[] = await this.queryTopic();
for (let i = 0; i < resData.length; i++) {
const dataQ: Resource = resData[i];
resList.push(new ResourceResp(
dataQ.getId(),
dataQ.getTitle(),
dataQ.getBrief(),
dataQ.getHeader_src(),
dataQ.getType(),
dataQ.getWeb_url(),
dataQ.getPublish_date(),
this.getTopicNames(topics, dataQ.getTopics()),
dataQ.getViews_count(),
dataQ.getCollect_count(),
dataQ.getLikes_count(),
dataQ.getTag(),
dataQ.getBanner_src(),
dataQ.getMedia_src(),
likedIds.indexOf(dataQ.getId()) !== -1,
collectedIds.indexOf(dataQ.getId()) !== -1,
null
));
}
}
return resList;
} catch (error) {
this.logger.error(`[collect] query resource error ${error}`);
}
}
async queryLikedIds(userId: string): Promise<string[]> {
const likedIds: string[] = [];
try {
const likeQuery: CloudDBZoneQuery<UserLike> = this.colUserLike.query().equalTo('user_id', userId);
const likeData: UserLike[] = await likeQuery.get();
for (let index = 0; index < likeData.length; index++) {
const element: UserLike = likeData[index];
likedIds.push(element.getResource_id());
}
return likedIds;
} catch (error) {
this.logger.error(`[collect] queryLikedIds error ${error}`);
}
}
async queryCollectedIds(userId: string): Promise<string[]> {
const collectedIds: string[] = [];
try {
const collectedQuery: CloudDBZoneQuery<Collect> = this.colCollect.query().equalTo('user_id', userId);
const collectedData: Collect[] = await collectedQuery.get();
for (let index = 0; index < collectedData.length; index++) {
const element: Collect = collectedData[index];
collectedIds.push(element.getResource_id());
}
return collectedIds;
} catch (error) {
this.logger.error(`[collect] queryCollectedIds error ${error}`);
}
}
async queryTopic(): Promise<Topic[]> {
const cloudDBZoneQuery: CloudDBZoneQuery<Topic> = this.colTopic.query();
const topicListData: Topic[] = await cloudDBZoneQuery.get();
return topicListData;
}
getTopicNames(topics: Topic[], tidStr: string): string[] {
const topicNames: string[] = [];
const topicIds: string[] = tidStr.split(',');
for (let index = 0; index < topicIds.length; index++) {
const tid: string = topicIds[index];
const tp: Topic[] = topics.filter(tp => tp.getId() === tid);
topicNames.push(tp[0].getName());
}
return topicNames;
}
}