instance lists

This commit is contained in:
ntr 2019-04-25 15:31:57 +10:00
parent eb2089cc17
commit 2f4944db10
8 changed files with 67 additions and 41 deletions

View File

@ -17,6 +17,7 @@ const COLOURS = [
function Menu(args) {
const {
account,
cryps,
selectedCryps,
setSelectedCryps,
@ -31,14 +32,12 @@ function Menu(args) {
if (!instances) return <div>...</div>;
const instancePanels = instances.map(instance => {
const globalInstance = instance.instance === NULL_UUID;
const name = globalInstance
? 'Global Matchmaking'
: `${instance.instance.substring(0, 5)} | ${instance.score.wins} : ${instance.score.losses}`;
const player = instance.players.find(p => p.account === account.id);
const name = `${instance.name} | ${player.score.wins} : ${player.score.losses}`;
return (
<button
className={`menu-instance-btn right ${globalInstance ? 'full' : ''}`}
className={'menu-instance-btn right'}
key={instance.id}
onClick={() => sendInstanceState(instance)}>
{name}

View File

@ -5,7 +5,7 @@ const actions = require('./../actions');
const addState = connect(
function receiveState(state) {
const { ws, cryps, selectedCryps, instances } = state;
const { ws, cryps, selectedCryps, instances, account } = state;
function sendInstanceJoin() {
if (selectedCryps.length) {
@ -26,10 +26,11 @@ const addState = connect(
}
function sendInstanceState(instance) {
return ws.sendInstanceState(instance.instance);
return ws.sendInstanceState(instance.id);
}
return {
account,
cryps,
selectedCryps,
sendInstanceJoin,

View File

@ -50,8 +50,8 @@ function createSocket(events) {
send({ method: 'account_cryps', params: {} });
}
function sendAccountPlayers() {
send({ method: 'account_players', params: {} });
function sendAccountInstances() {
send({ method: 'account_instances', params: {} });
}
function sendAccountZone() {
@ -171,10 +171,10 @@ function createSocket(events) {
localStorage.setItem('account', JSON.stringify(login));
events.setAccount(login);
sendAccountCryps();
sendAccountPlayers();
sendAccountInstances();
}
function accountPlayerList(res) {
function accountInstanceList(res) {
const [struct, playerList] = res;
events.setInstanceList(playerList);
}
@ -229,7 +229,7 @@ function createSocket(events) {
account_login: accountLogin,
account_create: accountLogin,
account_cryps: accountCryps,
account_players: accountPlayerList,
account_instances: accountInstanceList,
instance_scores: instanceScores,
zone_create: res => console.log(res),
zone_state: zoneState,
@ -285,7 +285,7 @@ function createSocket(events) {
if (account) {
events.setAccount(account);
sendAccountPlayers();
sendAccountInstances();
sendAccountCryps();
}
@ -319,7 +319,7 @@ function createSocket(events) {
sendAccountCreate,
sendAccountDemo,
sendAccountCryps,
sendAccountPlayers,
sendAccountInstances,
sendAccountZone,
sendGameState,
sendGameJoin,

View File

@ -27,7 +27,7 @@ class Home extends Phaser.Scene {
}
create() {
this.registry.get('ws').sendAccountPlayers();
this.registry.get('ws').sendAccountInstances();
this.registry.events.on('changedata', this.updateData, this);
this.registry.events.on('setdata', this.updateData, this);

View File

@ -45,8 +45,8 @@ function createSocket(events) {
send({ method: 'account_cryps', params: {} });
}
function sendAccountPlayers() {
send({ method: 'account_players', params: {} });
function sendAccountInstances() {
send({ method: 'account_instances', params: {} });
}
function sendAccountZone() {
@ -168,9 +168,9 @@ function createSocket(events) {
sendAccountCryps();
}
function accountPlayerList(res) {
const [struct, playerList] = res;
events.setPlayerList(playerList);
function accountInstanceList(res) {
const [struct, instanceList] = res;
events.setInstanceList(instanceList);
}
function accountCryps(response) {
@ -221,7 +221,7 @@ function createSocket(events) {
account_login: accountLogin,
account_create: accountLogin,
account_cryps: accountCryps,
account_players: accountPlayerList,
account_instances: accountInstanceList,
instance_scores: instanceScores,
zone_create: res => console.log(res),
zone_state: zoneState,
@ -302,7 +302,7 @@ function createSocket(events) {
sendAccountCreate,
sendAccountDemo,
sendAccountCryps,
sendAccountPlayers,
sendAccountInstances,
sendAccountZone,
sendGameState,
sendGamePve,

View File

@ -10,7 +10,7 @@ use postgres::transaction::Transaction;
use rpc::{AccountCreateParams, AccountLoginParams};
use cryp::{Cryp, cryp_recover};
use player::{Player, player_delete};
use instance::{Instance, instance_delete};
use failure::Error;
use failure::err_msg;
@ -177,11 +177,16 @@ pub fn account_cryps(tx: &mut Transaction, account: &Account) -> Result<Vec<Cryp
return Ok(cryps);
}
pub fn account_players(tx: &mut Transaction, account: &Account) -> Result<Vec<Player>, Error> {
pub fn account_instances(tx: &mut Transaction, account: &Account) -> Result<Vec<Instance>, Error> {
let query = "
SELECT data, id
FROM players
WHERE account = $1;
FROM instances
WHERE open = true
OR id IN (
SELECT instance
FROM players
WHERE account = $1
);
";
let result = tx
@ -193,15 +198,15 @@ pub fn account_players(tx: &mut Transaction, account: &Account) -> Result<Vec<Pl
let bytes: Vec<u8> = row.get(0);
let id = row.get(1);
match from_slice::<Player>(&bytes) {
match from_slice::<Instance>(&bytes) {
Ok(i) => list.push(i),
Err(_e) => {
player_delete(tx, id)?;
instance_delete(tx, id)?;
}
};
}
list.sort_by_key(|c| c.instance);
list.sort_unstable_by_key(|c| c.name.clone());
return Ok(list);
}

View File

@ -41,7 +41,7 @@ pub struct Instance {
open: bool,
max_players: usize,
password: Option<String>,
name: String,
pub name: String,
}
impl Instance {
@ -141,7 +141,7 @@ impl Instance {
self.start();
}
},
InstancePhase::Vbox =>
InstancePhase::Vbox => {
if self.all_ready() {
self.games_phase_start();
}
@ -306,7 +306,10 @@ impl Instance {
game = game.start();
assert!(game.finished());
let winner = game.winner().unwrap();
let winner = match game.winner() {
Some(w) => w,
None => panic!("game has no winner {:?}", game),
};
round.finished = true;
@ -479,6 +482,25 @@ pub fn instance_get(tx: &mut Transaction, instance_id: Uuid) -> Result<Instance,
return Ok(instance);
}
pub fn instance_delete(tx: &mut Transaction, id: Uuid) -> Result<(), Error> {
let query = "
DELETE
FROM instances
WHERE id = $1;
";
let result = tx
.execute(query, &[&id])?;
if result != 1 {
return Err(format_err!("unable to delete instance {:?}", id));
}
println!("instance deleted {:?}", id);
return Ok(());
}
pub fn instance_get_open(tx: &mut Transaction) -> Result<Instance, Error> {
let query = "
SELECT *
@ -511,7 +533,6 @@ pub fn instance_lobby(params: InstanceLobbyParams, tx: &mut Transaction, account
instance_join(join_params, tx, account)
}
pub fn instance_join(params: InstanceJoinParams, tx: &mut Transaction, account: &Account) -> Result<Instance, Error> {
let mut instance = instance_get(tx, params.instance_id)?;
@ -557,9 +578,9 @@ pub fn instance_scores(params: InstanceReadyParams, tx: &mut Transaction, _accou
}
pub fn instance_ready(params: InstanceReadyParams, tx: &mut Transaction, account: &Account) -> Result<Instance, Error> {
let player = player_get(tx, account.id, params.instance_id)?;
let mut instance = instance_get(tx, params.instance_id)?;
instance.player_ready(player.id)?;
let player_id = instance.account_player(account.id)?.id;
instance.player_ready(player_id)?;
instance_update(tx, instance)
}

View File

@ -17,7 +17,7 @@ use failure::err_msg;
use net::Db;
use cryp::{Cryp, cryp_spawn};
use game::{Game, game_state, game_skill};
use account::{Account, account_create, account_login, account_from_token, account_cryps, account_players};
use account::{Account, account_create, account_login, account_from_token, account_cryps, account_instances};
use skill::{Skill};
// use zone::{Zone, zone_create, zone_join, zone_close};
use spec::{Spec};
@ -64,7 +64,7 @@ impl Rpc {
// auth methods
"account_cryps" => Rpc::account_cryps(data, &mut tx, account.unwrap(), client),
"account_players" => Rpc::account_players(data, &mut tx, account.unwrap(), client),
"account_instances" => Rpc::account_instances(data, &mut tx, account.unwrap(), client),
// "account_zone" => Rpc::account_zone(data, &mut tx, account.unwrap(), client),
"cryp_spawn" => Rpc::cryp_spawn(data, &mut tx, account.unwrap(), client),
@ -210,10 +210,10 @@ impl Rpc {
})
}
fn account_players(_data: Vec<u8>, tx: &mut Transaction, account: Account, _client: &mut WebSocket<TcpStream>) -> Result<RpcResponse, Error> {
fn account_instances(_data: Vec<u8>, tx: &mut Transaction, account: Account, _client: &mut WebSocket<TcpStream>) -> Result<RpcResponse, Error> {
Ok(RpcResponse {
method: "account_players".to_string(),
params: RpcResult::PlayerList(account_players(tx, &account)?)
method: "account_instances".to_string(),
params: RpcResult::InstanceList(account_instances(tx, &account)?)
})
}
@ -391,7 +391,7 @@ pub enum RpcResult {
// ZoneState(Zone),
// ZoneClose(()),
PlayerList(Vec<Player>),
InstanceList(Vec<Instance>),
InstanceState(Instance),
}