Commit 81fea176 authored by mercury233's avatar mercury233

merge

parent c5b16dea
{
"port": 2333,
"version": 4921,
"port": 7911,
"ygopro_path": "ygopro",
"modules": {
"welcome": "YGOPRO Server",
......@@ -9,13 +8,21 @@
"tips": "http://mercury233.me/ygosrv233/tips.json",
"dialogues": "http://mercury233.me/ygosrv233/dialogues.json",
"redis_port": 6379,
"enable_websocket_roomlist": false,
"enable_random_duel": false,
"mycard_auth": false,
"post_start_watching": true,
"TCG_banlist_id": 8,
"enable_TCG_as_default": false,
"http": {
"port": 7922,
"password": "123456"
"password": "123456",
"ssl": {
"enabled": false,
"port": 7923,
"cert": "ssl/ygopro-server.crt",
"key": "ssl/ygopro-server.key"
}
}
}
}
......@@ -2,10 +2,7 @@
"name": "ygopro-server",
"version": "2.3.3",
"description": "a server for ygopro",
"repository": {
"type": "git",
"url": "https://github.com/mercury233/ygopro-server.git"
},
"repository": "github:mercury233/ygopro-server",
"keywords": [
"mycard",
"ygopro",
......@@ -13,18 +10,17 @@
],
"author": "zh99998 <zh99998@gmail.com>, mercury233 <me@mercury233.me>",
"dependencies": {
"underscore": "*",
"underscore.string": "*",
"request": "*",
"moment": "*",
"bunyan": "*"
"underscore": "latest",
"underscore.string": "latest",
"request": "latest",
"moment": "latest",
"sqlite3": "latest",
"bunyan": "latest",
"ws": "latest",
"pg": "latest"
},
"license": "GPL-3.0",
"main": "ygopro-server.js",
"license": "AGPL-3.0",
"scripts": {
"start": "pm2 start ygopro-server.js"
},
"engines": {
"node": "*"
"start": "node ygopro-server.js"
}
}
......@@ -4,6 +4,7 @@ _.mixin(_.str.exports());
spawn = require('child_process').spawn
spawnSync = require('child_process').spawnSync
ygopro = require './ygopro.js'
roomlist = require './roomlist' if settings.modules.enable_websocket_roomlist
bunyan = require 'bunyan'
moment = require 'moment'
#redis = require 'redis'
......@@ -134,7 +135,7 @@ class Room
room_pass = room_name_and_pass[1]
client_name == room_name and client_pass != room_pass
constructor: (name) ->
constructor: (name, @hostinfo) ->
@name = name
@alive = true
@players = []
......@@ -148,7 +149,7 @@ class Room
@welcome = ''
Room.all.push this
@hostinfo =
@hostinfo ||=
lflist: 0
rule: if settings.modules.enable_TCG_as_default then 2 else 0
mode: 0
......@@ -308,6 +309,7 @@ class Room
@process.stdout.setEncoding('utf8')
@process.stdout.once 'data', (data)=>
@established = true
roomlist.create(this) if !@private and settings.modules.enable_websocket_roomlist
@port = parseInt data
_.each @players, (player)=>
player.server.connect @port, '127.0.0.1',=>
......@@ -350,6 +352,7 @@ class Room
index = _.indexOf(Room.all, this)
#Room.all[index] = null unless index == -1
Room.all.splice(index, 1) unless index == -1
roomlist.delete @name if !@private and !@started and @established and settings.modules.enable_websocket_roomlist
return
get_playing_player: ->
......@@ -380,6 +383,7 @@ class Room
Room.players_oppentlist[client.remoteAddress] = null
if @established
roomlist.update(this) if !@private and !@started and settings.modules.enable_websocket_roomlist
client.server.connect @port, '127.0.0.1', ->
client.server.write buffer for buffer in client.pre_establish_buffers
client.established = true
......@@ -401,6 +405,7 @@ class Room
Room.ban_player(client.name, client.ip, "强退")
if @players.length
ygopro.stoc_send_chat_to_room this, "#{client.name} #{'离开了游戏'}#{if error then ": #{error}" else ''}"
roomlist.update(this) if !@private and !@started and settings.modules.enable_websocket_roomlist
#client.room = null
else
@process.kill()
......
// Generated by CoffeeScript 1.10.0
(function() {
var Room, _, bunyan, get_memory_usage, log, moment, settings, spawn, spawnSync, ygopro;
var Room, _, bunyan, get_memory_usage, log, moment, roomlist, settings, spawn, spawnSync, ygopro;
_ = require('underscore');
......@@ -14,6 +14,10 @@
ygopro = require('./ygopro.js');
if (settings.modules.enable_websocket_roomlist) {
roomlist = require('./roomlist');
}
bunyan = require('bunyan');
moment = require('moment');
......@@ -184,8 +188,9 @@
});
};
function Room(name) {
function Room(name, hostinfo) {
var draw_count, error1, lflist, param, rule, start_hand, start_lp, time_limit;
this.hostinfo = hostinfo;
this.name = name;
this.alive = true;
this.players = [];
......@@ -198,7 +203,7 @@
this.random_type = '';
this.welcome = '';
Room.all.push(this);
this.hostinfo = {
this.hostinfo || (this.hostinfo = {
lflist: 0,
rule: settings.modules.enable_TCG_as_default ? 2 : 0,
mode: 0,
......@@ -209,7 +214,7 @@
start_hand: 5,
draw_count: 1,
time_limit: 180
};
});
if (name.slice(0, 2) === 'M#') {
this.hostinfo.mode = 1;
} else if (name.slice(0, 2) === 'T#') {
......@@ -391,6 +396,9 @@
this.process.stdout.once('data', (function(_this) {
return function(data) {
_this.established = true;
if (!_this["private"] && settings.modules.enable_websocket_roomlist) {
roomlist.create(_this);
}
_this.port = parseInt(data);
_.each(_this.players, function(player) {
player.server.connect(_this.port, '127.0.0.1', function() {
......@@ -447,6 +455,9 @@
if (index !== -1) {
Room.all.splice(index, 1);
}
if (!this["private"] && !this.started && this.established && settings.modules.enable_websocket_roomlist) {
roomlist["delete"](this.name);
}
};
Room.prototype.get_playing_player = function() {
......@@ -489,6 +500,9 @@
}
}
if (this.established) {
if (!this["private"] && !this.started && settings.modules.enable_websocket_roomlist) {
roomlist.update(this);
}
client.server.connect(this.port, '127.0.0.1', function() {
var buffer, i, len, ref;
ref = client.pre_establish_buffers;
......@@ -520,6 +534,9 @@
}
if (this.players.length) {
ygopro.stoc_send_chat_to_room(this, client.name + " " + '离开了游戏' + (error ? ": " + error : ''));
if (!this["private"] && !this.started && settings.modules.enable_websocket_roomlist) {
roomlist.update(this);
}
} else {
this.process.kill();
this["delete"]();
......
WebSocketServer = require('ws').Server;
server = null
room_data = (room)->
id: room.name,
title: room.title,
user: {username: room.username}
users: ({username: client.name, position: client.pos} for client in room.players),
options: room.hostinfo
init = (http_server, Room)->
server = new WebSocketServer
server: http_server
server.on 'connection', (connection) ->
connection.send JSON.stringify
event: 'init'
data: room_data(room) for room in Room.all when room.established and !room.private and !room.started
create = (room)->
broadcast('create', room_data(room))
update = (room)->
broadcast('update', room_data(room))
_delete = (room_id)->
broadcast('delete', room_id)
broadcast = (event, data)->
return if !server
message = JSON.stringify
event: event
data: data
for connection in server.clients
try
connection.send message
module.exports =
init: init
create: create
update: update
delete: _delete
\ No newline at end of file
// Generated by CoffeeScript 1.10.0
(function() {
var WebSocketServer, _delete, broadcast, create, init, room_data, server, update;
WebSocketServer = require('ws').Server;
server = null;
room_data = function(room) {
var client;
return {
id: room.name,
title: room.title,
user: {
username: room.username
},
users: (function() {
var i, len, ref, results;
ref = room.players;
results = [];
for (i = 0, len = ref.length; i < len; i++) {
client = ref[i];
results.push({
username: client.name,
position: client.pos
});
}
return results;
})(),
options: room.hostinfo
};
};
init = function(http_server, Room) {
server = new WebSocketServer({
server: http_server
});
return server.on('connection', function(connection) {
var room;
return connection.send(JSON.stringify({
event: 'init',
data: (function() {
var i, len, ref, results;
ref = Room.all;
results = [];
for (i = 0, len = ref.length; i < len; i++) {
room = ref[i];
if (room.established && !room["private"] && !room.started) {
results.push(room_data(room));
}
}
return results;
})()
}));
});
};
create = function(room) {
return broadcast('create', room_data(room));
};
update = function(room) {
return broadcast('update', room_data(room));
};
_delete = function(room_id) {
return broadcast('delete', room_id);
};
broadcast = function(event, data) {
var connection, i, len, message, ref, results;
if (!server) {
return;
}
message = JSON.stringify({
event: event,
data: data
});
ref = server.clients;
results = [];
for (i = 0, len = ref.length; i < len; i++) {
connection = ref[i];
try {
results.push(connection.send(message));
} catch (undefined) {}
}
return results;
};
module.exports = {
init: init,
create: create,
update: update,
"delete": _delete
};
}).call(this);
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment