mirror of
https://activitypub.software/TransFem-org/Sharkey
synced 2024-11-27 16:33:02 +00:00
wip
This commit is contained in:
parent
8f9519db95
commit
06eabcbc63
6 changed files with 148 additions and 0 deletions
18
src/api/endpoints/othello/sessions/create.ts
Normal file
18
src/api/endpoints/othello/sessions/create.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import rndstr from 'rndstr';
|
||||||
|
import Session, { pack } from '../../../models/othello-session';
|
||||||
|
|
||||||
|
module.exports = (params, user) => new Promise(async (res, rej) => {
|
||||||
|
// 以前のセッションはすべて削除しておく
|
||||||
|
await Session.remove({
|
||||||
|
user_id: user._id
|
||||||
|
});
|
||||||
|
|
||||||
|
// セッションを作成
|
||||||
|
const session = await Session.insert({
|
||||||
|
user_id: user._id,
|
||||||
|
code: rndstr('a-z0-9', 3)
|
||||||
|
});
|
||||||
|
|
||||||
|
// Reponse
|
||||||
|
res(await pack(session));
|
||||||
|
});
|
34
src/api/endpoints/othello/sessions/in.ts
Normal file
34
src/api/endpoints/othello/sessions/in.ts
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
import $ from 'cafy';
|
||||||
|
import Session from '../../../models/othello-session';
|
||||||
|
import Game, { pack } from '../../../models/othello-game';
|
||||||
|
|
||||||
|
module.exports = (params, user) => new Promise(async (res, rej) => {
|
||||||
|
// Get 'code' parameter
|
||||||
|
const [code, codeErr] = $(params.code).string().$;
|
||||||
|
if (codeErr) return rej('invalid code param');
|
||||||
|
|
||||||
|
// Fetch session
|
||||||
|
const session = await Session.findOne({ code });
|
||||||
|
|
||||||
|
if (session == null) {
|
||||||
|
return rej('session not found');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Destroy session
|
||||||
|
Session.remove({
|
||||||
|
_id: session._id
|
||||||
|
});
|
||||||
|
|
||||||
|
const parentIsBlack = Math.random() > 0.5;
|
||||||
|
|
||||||
|
// Start game
|
||||||
|
const game = await Game.insert({
|
||||||
|
created_at: new Date(),
|
||||||
|
black_user_id: parentIsBlack ? session.user_id : user._id,
|
||||||
|
white_user_id: parentIsBlack ? user._id : session.user_id,
|
||||||
|
logs: []
|
||||||
|
});
|
||||||
|
|
||||||
|
// Reponse
|
||||||
|
res(await pack(game));
|
||||||
|
});
|
33
src/api/models/othello-game.ts
Normal file
33
src/api/models/othello-game.ts
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
import * as mongo from 'mongodb';
|
||||||
|
import deepcopy = require('deepcopy');
|
||||||
|
import db from '../../db/mongodb';
|
||||||
|
|
||||||
|
const Game = db.get<IGame>('othello_games');
|
||||||
|
export default Game;
|
||||||
|
|
||||||
|
export interface IGame {
|
||||||
|
_id: mongo.ObjectID;
|
||||||
|
created_at: Date;
|
||||||
|
black_user_id: mongo.ObjectID;
|
||||||
|
white_user_id: mongo.ObjectID;
|
||||||
|
logs: any[];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pack an othello game for API response
|
||||||
|
*
|
||||||
|
* @param {any} game
|
||||||
|
* @return {Promise<any>}
|
||||||
|
*/
|
||||||
|
export const pack = (
|
||||||
|
game: any
|
||||||
|
) => new Promise<any>(async (resolve, reject) => {
|
||||||
|
|
||||||
|
const _game = deepcopy(game);
|
||||||
|
|
||||||
|
// Rename _id to id
|
||||||
|
_game.id = _game._id;
|
||||||
|
delete _game._id;
|
||||||
|
|
||||||
|
resolve(_game);
|
||||||
|
});
|
29
src/api/models/othello-session.ts
Normal file
29
src/api/models/othello-session.ts
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import * as mongo from 'mongodb';
|
||||||
|
import deepcopy = require('deepcopy');
|
||||||
|
import db from '../../db/mongodb';
|
||||||
|
|
||||||
|
const Session = db.get<ISession>('othello_sessions');
|
||||||
|
export default Session;
|
||||||
|
|
||||||
|
export interface ISession {
|
||||||
|
_id: mongo.ObjectID;
|
||||||
|
code: string;
|
||||||
|
user_id: mongo.ObjectID;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pack an othello session for API response
|
||||||
|
*
|
||||||
|
* @param {any} session
|
||||||
|
* @return {Promise<any>}
|
||||||
|
*/
|
||||||
|
export const pack = (
|
||||||
|
session: any
|
||||||
|
) => new Promise<any>(async (resolve, reject) => {
|
||||||
|
|
||||||
|
const _session = deepcopy(session);
|
||||||
|
|
||||||
|
delete _session._id;
|
||||||
|
|
||||||
|
resolve(_session);
|
||||||
|
});
|
|
@ -21,6 +21,7 @@ import urlPreview from './url-preview.vue';
|
||||||
import twitterSetting from './twitter-setting.vue';
|
import twitterSetting from './twitter-setting.vue';
|
||||||
import fileTypeIcon from './file-type-icon.vue';
|
import fileTypeIcon from './file-type-icon.vue';
|
||||||
import Switch from './switch.vue';
|
import Switch from './switch.vue';
|
||||||
|
import Othello from './othello.vue';
|
||||||
|
|
||||||
Vue.component('mk-signin', signin);
|
Vue.component('mk-signin', signin);
|
||||||
Vue.component('mk-signup', signup);
|
Vue.component('mk-signup', signup);
|
||||||
|
@ -43,3 +44,4 @@ Vue.component('mk-url-preview', urlPreview);
|
||||||
Vue.component('mk-twitter-setting', twitterSetting);
|
Vue.component('mk-twitter-setting', twitterSetting);
|
||||||
Vue.component('mk-file-type-icon', fileTypeIcon);
|
Vue.component('mk-file-type-icon', fileTypeIcon);
|
||||||
Vue.component('mk-switch', Switch);
|
Vue.component('mk-switch', Switch);
|
||||||
|
Vue.component('mk-othello', Othello);
|
||||||
|
|
32
src/web/app/common/views/components/othello.vue
Normal file
32
src/web/app/common/views/components/othello.vue
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<div v-if="session">
|
||||||
|
<h1>相手を待っています<mk-ellipsis/></h1>
|
||||||
|
<p>セッションID:<code>{{ session.code }}</code></p>
|
||||||
|
<p>対戦したい相手に上記のセッションIDを伝えてください。相手が「セッションイン」でセッションIDを入力すると、対局が開始されます。</p>
|
||||||
|
</div>
|
||||||
|
<div v-else>
|
||||||
|
<h1>Misskey Othello</h1>
|
||||||
|
<p>他のMisskeyユーザーとオセロで対戦しよう。</p>
|
||||||
|
<button>フリーマッチ(準備中)</button>
|
||||||
|
<button @click="inSession">セッションイン</button>
|
||||||
|
<button @click="createSession">セッションを作成する</button>
|
||||||
|
<section>
|
||||||
|
<h2>過去の対局</h2>
|
||||||
|
</section>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script lang="ts">
|
||||||
|
import Vue from 'vue';
|
||||||
|
export default Vue.extend({
|
||||||
|
methods: {
|
||||||
|
createSession() {
|
||||||
|
(this as any).api('othello/sessions/create');
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
Loading…
Reference in a new issue