summaryrefslogtreecommitdiff
path: root/src/server/api/endpoints/games
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/api/endpoints/games')
-rw-r--r--src/server/api/endpoints/games/reversi/games/surrender.ts59
1 files changed, 59 insertions, 0 deletions
diff --git a/src/server/api/endpoints/games/reversi/games/surrender.ts b/src/server/api/endpoints/games/reversi/games/surrender.ts
new file mode 100644
index 0000000000..49821650ed
--- /dev/null
+++ b/src/server/api/endpoints/games/reversi/games/surrender.ts
@@ -0,0 +1,59 @@
+import $ from 'cafy'; import ID from '../../../../../../misc/cafy-id';
+import ReversiGame, { pack } from '../../../../../../models/games/reversi/game';
+import { ILocalUser } from '../../../../../../models/user';
+import getParams from '../../../../get-params';
+import { publishReversiGameStream } from '../../../../../../stream';
+
+export const meta = {
+ desc: {
+ ja: '指定したリバーシの対局で投了します。'
+ },
+
+ requireCredential: true,
+
+ params: {
+ gameId: $.type(ID).note({
+ desc: {
+ ja: '投了したい対局'
+ }
+ })
+ }
+};
+
+export default (params: any, user: ILocalUser) => new Promise(async (res, rej) => {
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) return rej(psErr);
+
+ const game = await ReversiGame.findOne({ _id: ps.gameId });
+
+ if (game == null) {
+ return rej('game not found');
+ }
+
+ if (game.isEnded) {
+ return rej('this game is already ended');
+ }
+
+ if (!game.user1Id.equals(user._id) && !game.user2Id.equals(user._id)) {
+ return rej('access denied');
+ }
+
+ const winnerId = game.user1Id.equals(user._id) ? game.user2Id : game.user1Id;
+
+ await ReversiGame.update({
+ _id: game._id
+ }, {
+ $set: {
+ surrendered: user._id,
+ isEnded: true,
+ winnerId: winnerId
+ }
+ });
+
+ publishReversiGameStream(game._id, 'ended', {
+ winnerId: winnerId,
+ game: await pack(game._id, user)
+ });
+
+ res();
+});