mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2024-11-30 14:13:08 +02: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 fileTypeIcon from './file-type-icon.vue';
|
||||
import Switch from './switch.vue';
|
||||
import Othello from './othello.vue';
|
||||
|
||||
Vue.component('mk-signin', signin);
|
||||
Vue.component('mk-signup', signup);
|
||||
|
@ -43,3 +44,4 @@ Vue.component('mk-url-preview', urlPreview);
|
|||
Vue.component('mk-twitter-setting', twitterSetting);
|
||||
Vue.component('mk-file-type-icon', fileTypeIcon);
|
||||
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