Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Sign in / Register
Toggle navigation
R
railgun-routing-client
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Locked Files
Issues
0
Issues
0
List
Boards
Labels
Service Desk
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Security & Compliance
Security & Compliance
Dependency List
License Compliance
Packages
Packages
List
Container Registry
Analytics
Analytics
CI / CD
Code Review
Insights
Issues
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Railgun
railgun-routing-client
Commits
a3a68030
Commit
a3a68030
authored
Oct 30, 2015
by
神楽坂玲奈
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
init
parents
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
50 additions
and
0 deletions
+50
-0
.gitignore
.gitignore
+2
-0
db.coffee
db.coffee
+36
-0
main.coffee
main.coffee
+12
-0
No files found.
.gitignore
0 → 100644
View file @
a3a68030
/.idea/
\ No newline at end of file
db.coffee
0 → 100644
View file @
a3a68030
pg
=
require
'pg'
module
.
exports
=
init
:
(
server_id
,
database
)
->
pg
.
connect
database
,
(
error
,
client
,
done
)
->
throw
error
if
error
client
.
query
'SELECT * from servers'
,
(
error
,
result
)
->
throw
error
if
error
servers
=
{}
for
row
in
result
.
rows
servers
[
row
.
id
]
=
row
client
.
query
'SELECT * from links where from = $1::int or to = $1::int'
,
[
server_id
],
(
error
,
result
)
->
throw
error
if
error
for
row
in
result
.
rows
if
row
.
from
==
server_id
servers
[
row
.
to
].
link
=
row
else
servers
[
row
.
from
].
link
=
row
client
.
query
'SELECT id FROM regions'
,
(
error
,
result
)
->
throw
error
if
error
regions
=
{}
for
row
in
result
.
rows
regions
[
row
.
id
]
=
addresses
:
[]
client
.
query
'SELECT region_id, address FROM addresses'
,
(
error
,
result
)
->
throw
error
if
error
for
row
in
result
.
rows
regions
[
row
.
region_id
].
addresses
.
push
row
.
address
reachable_servers
=
(
server
.
id
for
server
in
servers
when
server
.
link
?
)
reachable_servers
.
push
server_id
client
.
query
'SELECT DISTINCT ON (region_id) region_id, server_id FROM gateways WHERE server_id in $1 ORDER BY delay'
,
[
reachable_servers
],
(
error
,
result
)
->
throw
error
if
error
for
row
in
result
.
rows
regions
[
row
.
region_id
].
gateway
=
row
.
server_id
done
()
callback
servers
,
regions
\ No newline at end of file
main.coffee
0 → 100644
View file @
a3a68030
db
=
require
'./db.coffee'
protocol
=
require
'./protocol'
route
=
require
'./route'
server_id
=
parseInt
process
.
env
.
RAILGUN_SERVER_ID
db
.
init
server_id
,
process
.
env
.
RAILGUN_DATABASE
,
(
servers
,
regions
)
->
console
.
log
servers
,
regions
#route.init server_id, servers, regions, ->
# protocol.init server_id, servers, regions, route.update
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment