-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
268ac31
commit 595cdd5
Showing
21 changed files
with
817 additions
and
434 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,142 @@ | ||
import Database "./database"; | ||
import Types "./types"; | ||
import Principal "mo:base/Principal"; | ||
import TrieMap "mo:base/TrieMap"; | ||
import Array "mo:base/Array"; | ||
import Order "mo:base/Order"; | ||
import Time "mo:base/Time"; | ||
import Debug "mo:base/Debug"; | ||
import Option "mo:base/Option"; | ||
import Bucket "../post/bucket"; | ||
|
||
actor class Feed( | ||
_owner: Principal, | ||
rootPostCanister: Principal, | ||
userCanister: Principal | ||
) = this { | ||
|
||
stable var owner = _owner; | ||
|
||
public query func getOwner(): async Principal { owner }; | ||
|
||
public shared({caller}) func updateOwner(newOwner: Principal): async () { | ||
assert(caller == owner); | ||
owner := newOwner; | ||
}; | ||
|
||
public query({caller}) func whoami(): async Principal { caller }; | ||
|
||
// Bucket | ||
|
||
type RootPostActor = Types.RootPostActor; | ||
stable var bucket: ?Principal = null; | ||
let rootPostActor: RootPostActor = actor(Principal.toText(rootPostCanister)); | ||
|
||
// 更新当前 feed 去存储的 bucket canister | ||
public shared func checkAvailableBucket(): async Bool { | ||
switch((await rootPostActor.getAvailableBucket())) { | ||
case(null) { return false; }; | ||
case(?bucketInfo) { | ||
bucket := ?bucketInfo.canisterId; | ||
return true; | ||
}; | ||
}; | ||
}; | ||
|
||
// Post | ||
|
||
type Time = Types.Time; | ||
type UserId = Types.UserId; | ||
type BucketActor = Types.BucketActor; | ||
|
||
let postDirectory: Database.PostDirectory = Database.PostDirectory(); | ||
|
||
public shared({caller}) func createPost(title: Text, content: Text): async Bool { | ||
assert(caller == owner and bucket != null); | ||
let _bucket = Option.unwrap(bucket); | ||
let post: PostImmutable = postDirectory.createPost(caller, title, content, Time.now(), _bucket); | ||
|
||
// 将帖子内容发送给公共区的 Bucket | ||
let bucketActor: BucketActor = actor(Principal.toText(_bucket)); | ||
ignore bucketActor.storeFeed(post); | ||
|
||
// 把发帖人、帖子 ID 、用户 C 、D(followers)发送给 Fetch | ||
true | ||
}; | ||
|
||
// public query func getPost(postIndex: Nat): async ?PostImmutable { | ||
// postDirectory.getPost(postIndex) | ||
// }; | ||
|
||
// public query func getPosts(): async [PostImmutable] { | ||
// postDirectory.getPosts() | ||
// }; | ||
|
||
// public shared({caller}) func createComment(commentUser: UserId, postIndex: Nat, content: Text): async ?Nat { | ||
// assert(caller == postCanister or caller == owner); | ||
// let commentIndex = postDirectory.createComment(commentUser, postIndex, content, Time.now()); | ||
// await sendFeed(); | ||
// commentIndex | ||
// }; | ||
|
||
// public shared({caller}) func deleteComment(commentUser: UserId, postIndex: Nat, commentIndex: Nat): async () { | ||
// assert(caller == rootPostCanister); | ||
// postDirectory.deleteComment(commentUser, postIndex, commentIndex); | ||
// await sendFeed(); | ||
// }; | ||
|
||
// public shared({caller}) func createLike(likeUser: UserId, postIndex: Nat): async () { | ||
// assert(caller == postCanister); | ||
// postDirectory.createLike(likeUser, postIndex, Time.now()); | ||
// await sendFeed(); | ||
// }; | ||
|
||
// public shared({caller}) func deleteLike(likeUser: UserId, postIndex: Nat) { | ||
// assert(caller == rootPostCanister); | ||
// postDirectory.deleteLike(likeUser, postIndex); | ||
// await sendFeed(); | ||
// }; | ||
|
||
// Feed | ||
|
||
type PostImmutable = Types.PostImmutable; | ||
type FeedActor = Types.FeedActor; | ||
type UserActor = Types.UserActor; | ||
|
||
// let postActor: PostActor = actor(Principal.toText(rootPostCanister)); | ||
let feedMap = TrieMap.TrieMap<Principal, [PostImmutable]>(Principal.equal, Principal.hash); | ||
|
||
// public shared({caller}) func sendFeed(): async () { | ||
// assert(caller == owner or caller == Principal.fromActor(this)); | ||
// let userActor: UserActor = actor(Principal.toText(userCanister)); | ||
// Debug.print("userCanister : " # Principal.toText(userCanister)); | ||
// let followersList = await userActor.getFollowersList(owner); | ||
// for(user in followersList.vals()) { | ||
// let feedActor: FeedActor = actor(Principal.toText(user)); | ||
// await feedActor.receiveFeed(); | ||
// }; | ||
// await postActor.receiveFeed(); | ||
// }; | ||
|
||
public shared({caller}) func receiveFeed(): async () { | ||
let feedActor: FeedActor = actor(Principal.toText(caller)); | ||
let posts = await feedActor.getPosts(); | ||
feedMap.put(caller, posts); | ||
}; | ||
|
||
public query({caller}) func getFeed(): async [PostImmutable] { | ||
var ans: [PostImmutable] = []; | ||
for(posts in feedMap.vals()) { | ||
ans := Array.append<PostImmutable>(ans, posts); | ||
}; | ||
Array.sort( | ||
ans, | ||
func (x: PostImmutable, y: PostImmutable): Order.Order { | ||
if(x.createdAt > y.createdAt) return #less | ||
else if(x.createdAt < y.createdAt) return #greater | ||
else return #equal | ||
} | ||
) | ||
}; | ||
|
||
} |
Oops, something went wrong.