Skip to content

Commit eafc7ac

Browse files
committed
Added project
1 parent 383cfc1 commit eafc7ac

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

55 files changed

+31890
-1
lines changed

README.TXT

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
To execute ciborg-server in the regular way just execute :
2+
3+
`npm start`
4+
5+
If you wish to run ciborg-server using mock data execute it in the following way :
6+
7+
`npm run start-test`
8+
9+
If you don't define ciborg-server execution like in the previous example, ciborg-server will execute the regular way.

README.md

+34-1
Original file line numberDiff line numberDiff line change
@@ -1 +1,34 @@
1-
# BoardGames
1+
## Board Games API and Web Application
2+
3+
The Board Games Web Application was built for a project in the Programming in the Internet course in ISEL.
4+
Developed this project with [Rui](https://github.com/RuiPacas) and [Margarida](https://github.com/MargaridaNunes) during my course.
5+
6+
Manage your own board games groups, edited them, create your own user and more.
7+
8+
Web API built using Node Runtime enviromment, express module, request-promise module, async/await, passport.
9+
10+
Web Application built using HTML, CSS, BootStrap Framework, Handlebars, Fetch API and Webpack.
11+
12+
The API Documentation can be found [here](https://github.com/RodrasSilva/BoardGames/wiki/Board-Games-API-Documentation).
13+
14+
### How to run the App
15+
16+
To run the application you will need :
17+
- Elasticsearch (https://www.elastic.co/downloads/)
18+
- Webpack
19+
- webpack : npm install -g webpack
20+
- webpack-cli : npm install -g webpack-cli
21+
22+
Follow these steps to run the app :
23+
24+
1. Run ElasticSearch
25+
2. Open an terminal window in the project directory
26+
3. Run : `curl -X DELETE "localhost:9200/groups?pretty"` in the command line
27+
4. Run : `curl -X DELETE "localhost:9200/users?pretty"` in the command line
28+
5. Run : `npm install`
29+
6. Run : `npm start` ou `npm run start`
30+
7. Open another terminal in the folder `.../{projectDirectory}/app`
31+
8. Run : `npm install`
32+
9. Run : `webpack -w`
33+
34+
Both the Server and Client are running in the port 8080

app/entry.js

+5
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
'use strict';
2+
require('./node_modules/bootstrap/dist/css/bootstrap.css')
3+
require('jquery')
4+
require('./node_modules/bootstrap/dist/js/bootstrap.js')
5+
require('./js/state-router')

app/index.html

+27
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,27 @@
1+
<!DOCTYPE html>
2+
<html>
3+
<head>
4+
<link rel="icon" href="https://www.boardgameatlas.com/imgs/5cc-api-logo.png">
5+
<title>Chelas Internet Board Games</title>
6+
</head>
7+
<body>
8+
<nav class="navbar navbar-expand-lg navbar-light bg-light">
9+
10+
<a class="navbar-brand" href="#home">
11+
Chelas Internet Board Games
12+
<img src=""
13+
width ="20" height="20">
14+
</a>
15+
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup" aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
16+
<span class="navbar-toggler-icon"></span>
17+
</button>
18+
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
19+
<div class="navbar-nav" id = "navBarResults">
20+
21+
</div>
22+
</div>
23+
</nav>
24+
<div id ="ciborg-alert"></div>
25+
<div id="results"></div>
26+
</body>
27+
</html>
+112
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,112 @@
1+
const data = require('../model/ciborg-data')
2+
3+
function updateState(routeManager){
4+
return data.isSessionActive()
5+
.then(session => {
6+
routeManager.context.login = session
7+
})
8+
}
9+
10+
11+
module.exports = {
12+
home: async function (routeManager) {
13+
return updateState(routeManager).then(()=>{})
14+
},
15+
games: async function (routeManager) {
16+
return updateState(routeManager).then(()=>data.getPopularGames().then( data => {
17+
data.games.map( game => {
18+
game.description = game.description.slice(0,100) + "..." // Description too long
19+
return game
20+
})
21+
return data;
22+
}))
23+
},
24+
searchGamesWithName: async function (routeManager, name, ) {
25+
return updateState(routeManager).then(()=>data.getSpecificGameWithName(name)
26+
.then(data => {
27+
data.games.map( game => {
28+
game.description = game.description.slice(0,100) + "..." // Description too long
29+
return game
30+
})
31+
return data;
32+
}))
33+
},
34+
groups: async function (routeManager) {
35+
return updateState(routeManager).then(()=> data.getGroups()
36+
.then( data => {
37+
data.groups = data.groups.sort((g1,g2) => g1.name>g2.name ? 1 : g1.name<g2.name ? -1 : 0 )
38+
return data
39+
})
40+
)
41+
},
42+
about: async function (routeManager) {
43+
return updateState(routeManager).then(()=>{})
44+
},
45+
specificGroup: async function (routeManager, id) {
46+
return updateState(routeManager).then(()=>data.getSpecificGroupWithId(id).then(
47+
data=>{
48+
data.data.games.map( game => {
49+
game.description = game.description.slice(0,100) + "..." // Description too long
50+
return game
51+
})
52+
return data
53+
}
54+
))
55+
},
56+
createGroup: async function (routeManager, groupInfo) {
57+
return updateState(routeManager).then(()=>data.postGroup(groupInfo))
58+
},
59+
addGameToGroup: async function (routeManager, gameId) {
60+
return updateState(routeManager).then(()=>data.getGroups()
61+
.then((groups) => {
62+
groups.groups = groups.groups.filter( group => !group.games.includes(gameId))
63+
groups.groups = groups.groups.sort((g1,g2) => g1.name>g2.name ? 1 : g1.name<g2.name ? -1 : 0 )
64+
return { groups, gameId }
65+
}))
66+
},
67+
putGameIntoGroup: async function (routeManager, gameGroupInfo) {
68+
return updateState(routeManager).then(()=>data.putGameIntoGroup(gameGroupInfo))
69+
},
70+
editGroup: async function (routeManager, groupInfo) {
71+
return updateState(routeManager).then(()=>data.editGroup(groupInfo))
72+
},
73+
deleteGroup: async function (routeManager, groupId) {
74+
return updateState(routeManager).then(()=>data.deleteGroup(groupId))
75+
},
76+
deleteGroupGame: async function (routeManager, gameGroupInfo) {
77+
return updateState(routeManager).then(()=>data.deleteGroupGame(gameGroupInfo))
78+
},
79+
groupGamesBetweenTime: async function (routeManager, groupId, queryString) {
80+
return updateState(routeManager).then(()=>data.groupGamesBetweenTime(queryString,groupId))
81+
},
82+
signUp: async function (routeManager) {
83+
return updateState(routeManager).then(()=>{})
84+
},
85+
createUser: async function (routeManager, userInfo) {
86+
return updateState(routeManager).then(()=>data.createUser(userInfo))
87+
},
88+
userLogin: async function (routeManager) {
89+
return updateState(routeManager).then(()=>{})
90+
},
91+
login: async function (routeManager, loginInfo) {
92+
const username = loginInfo.username
93+
const password = loginInfo.password
94+
if(!routeManager.context.login){
95+
return data.login(username, password)
96+
.then( (data) => {
97+
routeManager.context.login = true
98+
routeManager.context.username = username
99+
return data
100+
})
101+
}
102+
},
103+
logout: async function (routeManager) {
104+
return updateState(routeManager)
105+
.then(() => data.logout())
106+
.then( (data) => {
107+
routeManager.context.login = false
108+
routeManager.context.username = undefined
109+
return data
110+
})
111+
}
112+
}

app/js/model/ciborg-data.js

+108
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,108 @@
1+
2+
function fetchResponse(uri, options, sucessStatusCode) {
3+
return fetch(uri, options
4+
).then(response => {
5+
return response.json()
6+
.then(parsedBody => {
7+
if (response.status == sucessStatusCode) return parsedBody
8+
parsedBody.statusCode = response.status;
9+
throw parsedBody
10+
})
11+
})
12+
}
13+
14+
function buildOptions(method, body) {
15+
const toReturn = {}
16+
toReturn.method = method
17+
toReturn.body = JSON.stringify(body)
18+
toReturn.headers = { 'Accept': 'application/json', 'Content-Type': 'application/json' }
19+
return toReturn
20+
}
21+
22+
function CiborgApiUris() {
23+
const baseUri = "http://localhost:8080/ciborg/api/"
24+
const baseUriAuth = `${baseUri}auth/`
25+
26+
this.getPopularGamesUri = () => `${baseUri}games`
27+
this.getSpecificGameWithNameUri = (name) => `${baseUri}games/${name}`
28+
this.getGroupsUri = () => `${baseUriAuth}groups`
29+
this.getSpecificGroupWithIdUri = (id) => `${baseUriAuth}groups/${id}`
30+
this.putGameIntoGroupUri = (groupId) => `${baseUriAuth}groups/${groupId}/games`
31+
this.deleteGroupGameUri = (groupId, gameId) => `${baseUriAuth}groups/${groupId}/games/${gameId}`
32+
this.groupGamesBetweenTimeUri = (queryString, groupId) => `${baseUriAuth}groups/${groupId}/games${queryString}`
33+
this.createUser = () => `${baseUri}users`
34+
this.login = () => `${baseUri}login`
35+
this.logout = () => `${baseUriAuth}logout`
36+
this.session = () => `${baseUri}session`
37+
}
38+
39+
const apiUris = new CiborgApiUris();
40+
41+
module.exports = {
42+
getPopularGames: function () {
43+
return fetchResponse(apiUris.getPopularGamesUri(), {}, 200)
44+
},
45+
getSpecificGameWithName: function (name) {
46+
return fetchResponse(apiUris.getSpecificGameWithNameUri(name), {}, 200)
47+
},
48+
getGroups: function () {
49+
return fetchResponse(apiUris.getGroupsUri(), {}, 200)
50+
},
51+
getSpecificGroupWithId: function (id) {
52+
return fetchResponse(apiUris.getSpecificGroupWithIdUri(id), {}, 200)
53+
.then(data => { return { data, groupId: id } })
54+
},
55+
postGroup: function (groupsInfo) {
56+
const options = buildOptions("POST", { name: groupsInfo.name, description: groupsInfo.description })
57+
return fetchResponse(apiUris.getGroupsUri(), options, 201);
58+
},
59+
putGameIntoGroup: function (gameGroupInfo) {
60+
const options = buildOptions("PUT", { idGame: gameGroupInfo.gameId })
61+
return fetchResponse(apiUris.putGameIntoGroupUri(gameGroupInfo.groupId),
62+
options, 201).then(data => gameGroupInfo)
63+
64+
},
65+
editGroup: function (groupInfo) {
66+
const options = buildOptions("PUT", { name: groupInfo.name, description: groupInfo.description })
67+
return fetchResponse(apiUris.getSpecificGroupWithIdUri(groupInfo.groupId),
68+
options, 200)
69+
.then(data => groupInfo)
70+
},
71+
deleteGroup: function (groupId) {
72+
const options = buildOptions("DELETE", {})
73+
return fetchResponse(apiUris.getSpecificGroupWithIdUri(groupId), options, 200)
74+
},
75+
deleteGroupGame: function (gameGroupInfo) {
76+
const options = buildOptions("DELETE", {})
77+
return fetchResponse(apiUris.deleteGroupGameUri(gameGroupInfo.groupId, gameGroupInfo.gameId),
78+
options, 200
79+
).then(data => gameGroupInfo)
80+
},
81+
groupGamesBetweenTime: function (queryString,groupId) {
82+
return fetchResponse(apiUris.groupGamesBetweenTimeUri(queryString, groupId),
83+
buildOptions("GET"), 200)
84+
.then(games => fetchResponse(apiUris.getSpecificGroupWithIdUri(groupId), buildOptions("GET"), 200)
85+
.then(r => {
86+
r.games = games.games
87+
return r
88+
})
89+
).then(data => { return { data, groupId } })
90+
},
91+
createUser: function (userInfo) {
92+
const options = buildOptions("POST", { username: userInfo.username, password: userInfo.password })
93+
return fetchResponse(apiUris.createUser(), options, 201)
94+
},
95+
login: function (username, password) {
96+
const options = buildOptions("POST", { username, password })
97+
return fetchResponse(apiUris.login(), options, 200)
98+
99+
},
100+
logout: function () {
101+
const options = buildOptions("PUT")
102+
return fetchResponse(apiUris.logout(), options, 200)
103+
.then( data => data )
104+
},
105+
isSessionActive : function () {
106+
return fetchResponse(apiUris.session(),{},200).then(data => data.status )
107+
}
108+
}

0 commit comments

Comments
 (0)