Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release v0.1.0 - Core #3

Merged
merged 211 commits into from
Apr 11, 2023
Merged
Changes from 1 commit
Commits
Show all changes
211 commits
Select commit Hold shift + click to select a range
ea29d03
chore: move front related files to front folder
Asiberus Aug 29, 2022
ab79952
chore: init django project and docker config
Asiberus Aug 29, 2022
345e195
feat: add user, spot, shop & bar models, serializers and views
Asiberus Aug 30, 2022
a48f55b
chore: move serializers and views to api app
Asiberus Aug 31, 2022
92cbcb4
feat: provide static with nginx
Asiberus Sep 1, 2022
7457a7b
feat: implement point getter on front side
Aug 31, 2022
fb264b1
feat: update login to include register in one page
Sep 3, 2022
d5f0a4f
feat: add reset password aside
ArthurBeaulieu Sep 12, 2022
739c2e1
update gitignore
ArthurBeaulieu Sep 12, 2022
e455858
chore(back): change userId to integer field
Asiberus Sep 12, 2022
1428ba5
feat(back): add welcome view
Asiberus Sep 12, 2022
c049458
chore(front): handle static url
Asiberus Sep 13, 2022
5f59ba3
Merge remote-tracking branch 'origin/backend' into frontend
ArthurBeaulieu Sep 14, 2022
70405b5
chore(front): fix static path
ArthurBeaulieu Sep 14, 2022
7359e41
feat(front): create communication class for csrf header
ArthurBeaulieu Sep 15, 2022
07ee752
fix(front): fix display spots latlng bug
ArthurBeaulieu Sep 15, 2022
5583033
feat(front): add proper api login call
ArthurBeaulieu Sep 15, 2022
b0a38d7
feat(front): rename all store in shop
ArthurBeaulieu Sep 17, 2022
b794363
feat(front): save marks to server
ArthurBeaulieu Sep 17, 2022
76e2db4
fix(front): freezed map after aside loading
ArthurBeaulieu Sep 17, 2022
df7dde0
feat(front): proper scss for welcom
ArthurBeaulieu Sep 17, 2022
1c38daa
feat(front): add front documentation and test baseline
ArthurBeaulieu Sep 17, 2022
b751bb1
feat(front): documentation and clearing useless methods in utils
ArthurBeaulieu Sep 17, 2022
1e1b155
feat(front): clean provider enum
ArthurBeaulieu Sep 17, 2022
a61111f
feat(front): enhance welcome page style and command
ArthurBeaulieu Sep 18, 2022
3cfb1b0
feat(back): move html from static to templates
ArthurBeaulieu Sep 18, 2022
04e53c8
feat(front): handle fatal error on frontend side
ArthurBeaulieu Sep 18, 2022
2ac4519
feat(front): add template in front testing
ArthurBeaulieu Sep 18, 2022
bfc6568
fix(front): add missing file
ArthurBeaulieu Sep 19, 2022
f0e96d4
feat: add login and logout
Asiberus Sep 19, 2022
2f10ac9
feat: add login and logout
Asiberus Sep 19, 2022
8fea716
Merge remote-tracking branch 'origin/backend' into frontend
ArthurBeaulieu Sep 19, 2022
3908493
fix(front): Kom resolution with no data for POST
ArthurBeaulieu Sep 19, 2022
e7bca29
feat: set user login for spot, shop, bar creation
Asiberus Sep 19, 2022
f95ed6d
Merge remote-tracking branch 'origin/backend' into frontend
ArthurBeaulieu Sep 19, 2022
309c092
feat(back): add endpoint to get user connected
Asiberus Sep 19, 2022
101e0a6
Merge remote-tracking branch 'origin/backend' into frontend
ArthurBeaulieu Sep 20, 2022
5587d0c
feat(front): use connected user endpoint
ArthurBeaulieu Sep 20, 2022
d9ee2b9
feat(front): delete and edit marks
ArthurBeaulieu Sep 20, 2022
0cc5feb
fix(front): pushing missing files
ArthurBeaulieu Sep 20, 2022
50026c1
feat(back): implement basic user register
Asiberus Sep 20, 2022
86582c9
build: add adminer container
Asiberus Sep 20, 2022
2690c2d
chore(back): set isActive to false at register
Asiberus Sep 20, 2022
0679e62
chore(back): use set_password to hash password
Asiberus Sep 20, 2022
d750f2f
feat(back): create email service
Asiberus Sep 20, 2022
61872c6
feat(back): send mail at register to activate user
Asiberus Sep 21, 2022
b03d63b
feat(back): add password reset request
Asiberus Sep 21, 2022
cede148
feat(back): add password reset endpoint
Asiberus Sep 21, 2022
6db37f9
feat(front): reset password aside wip
ArthurBeaulieu Sep 21, 2022
73c599b
feat(front): edit resetpassword url with uid and token
ArthurBeaulieu Sep 21, 2022
3a9cb26
feat(back): use mailjet service to send mail
Asiberus Sep 23, 2022
88cad35
feat: wip upload modal
ArthurBeaulieu Oct 22, 2022
887cbc5
add upload post on update pp
ArthurBeaulieu Oct 23, 2022
7cad9f2
clone nls en into fr
ArthurBeaulieu Oct 23, 2022
80308c0
committing files
ArthurBeaulieu Oct 23, 2022
e9c897c
another one
ArthurBeaulieu Oct 23, 2022
4e06f6b
ressize looks ok
ArthurBeaulieu Oct 23, 2022
f68cfd4
build: configure media file for django & nginx
Asiberus Oct 23, 2022
fcaa849
feat(back): handle profile picture for user
Asiberus Oct 23, 2022
bf5584b
fix: front call to user-profile api
Asiberus Oct 23, 2022
ecfb5bb
feat: drag resizer and touch
ArthurBeaulieu Oct 23, 2022
b4be9ce
Merge remote-tracking branch 'origin/backend' into frontend
ArthurBeaulieu Oct 23, 2022
d1b2bce
fix: not int in rq
ArthurBeaulieu Oct 23, 2022
acd2f23
fix: max undefined to server
ArthurBeaulieu Oct 23, 2022
4e60578
feat: proper coordinates for image cropping backend
ArthurBeaulieu Oct 23, 2022
c0bc1a9
feat: ui restyle
ArthurBeaulieu Oct 24, 2022
f38915b
fix: next time wont comit in front
ArthurBeaulieu Oct 24, 2022
f61d125
feat: auth button correction
ArthurBeaulieu Oct 24, 2022
e0f141b
feat: add base layers
ArthurBeaulieu Oct 24, 2022
82e7e1a
fix: missing nls
ArthurBeaulieu Oct 24, 2022
5e92bbd
feat: add type ui to new spot
ArthurBeaulieu Oct 30, 2022
e7ac5e2
fix: nls refacto and utils
ArthurBeaulieu Oct 30, 2022
ea4cfc7
wip: modal refactor, not up
ArthurBeaulieu Oct 31, 2022
6bfd9d9
wip: migrating modal to factory 2/3
ArthurBeaulieu Nov 2, 2022
9cba213
feat: modal factory to reduce main js file
ArthurBeaulieu Nov 2, 2022
693e267
feat: square resizer on landscape/portrait pictures
ArthurBeaulieu Nov 2, 2022
4e48149
feat: minor optim
ArthurBeaulieu Nov 3, 2022
cb111ee
feat: add light theme pref
ArthurBeaulieu Nov 3, 2022
89dd538
feat: add lang pref
ArthurBeaulieu Nov 3, 2022
55bbccd
feat: modal factorisation done
ArthurBeaulieu Nov 7, 2022
a14dc65
feat: improve clustering
ArthurBeaulieu Nov 7, 2022
96ef4eb
feat: move cmd to bottom for better mobild command
ArthurBeaulieu Nov 7, 2022
91ca6ec
fix: range circle bug at zoom 11
ArthurBeaulieu Nov 7, 2022
2da2571
feat: better pref at init
ArthurBeaulieu Nov 7, 2022
08af167
feat: front unit testing started
Nov 8, 2022
868594c
feat: unified auth and app style
ArthurBeaulieu Nov 9, 2022
b28d08f
fix: webpack failing to build assets
ArthurBeaulieu Dec 11, 2022
6db8789
feat: change nav flex direction
ArthurBeaulieu Dec 11, 2022
6959eb3
chore(back): clean user profile picture serializer
Asiberus Oct 23, 2022
b470d70
feat(back): remove file if user's profile picture is updated or deleted
Asiberus Oct 24, 2022
c6b419b
chore(back): set default permission to IsAuthenticatedOrReadonly
Asiberus Dec 11, 2022
7b1f63c
feat(back): add is owner permission in spot, bar & shop views
Asiberus Dec 11, 2022
597f511
chore(back): set editable to false for user field in spot, bar & shop…
Asiberus Dec 11, 2022
528307f
feat(back): add modifiers and types to spot, bar & shop models and se…
Asiberus Dec 12, 2022
3040fe3
refactor: merge serializers for shop, spot & bar
Asiberus Dec 22, 2022
5541426
feat(back): add price in shop and bar models
Asiberus Dec 22, 2022
0c95a8d
chore(back): set modifiers and types required for spot, shop and bars
Asiberus Dec 23, 2022
76675dc
Merge pull request #1 from MesseBasseProduction/backend
Asiberus Jan 9, 2023
84e8a57
fix: style on auth login aside
ArthurBeaulieu Jan 9, 2023
58fcc27
feat: update package.json
ArthurBeaulieu Jan 9, 2023
90e53e1
fix: aside transparency on register/reset passwd
ArthurBeaulieu Jan 9, 2023
dda7066
fix: redirect after register with check your email notice
ArthurBeaulieu Jan 9, 2023
70da945
fix: proper message on reset password
ArthurBeaulieu Jan 9, 2023
e38d556
fix: remove unused parameters
ArthurBeaulieu Jan 9, 2023
bdf7704
fix(back): set modifiers to required false
Asiberus Jan 10, 2023
d9f7e3c
chore(back): set price enum start to 0
Asiberus Jan 10, 2023
bdcf645
chore(back): add isStaff property in user serializer
Asiberus Jan 10, 2023
9823719
chore: add backupdb command
Asiberus Jan 10, 2023
dc07f1b
fix: miscelaneous issues, wip for full convergence
ArthurBeaulieu Jan 11, 2023
1c7557d
fix: image resizer now ok
ArthurBeaulieu Jan 11, 2023
fb29229
fix: add/edit modal width and height full screen
ArthurBeaulieu Jan 11, 2023
6b171bb
fix: proper translations
ArthurBeaulieu Jan 14, 2023
1f60353
fix: end translations first pass
ArthurBeaulieu Jan 14, 2023
fa2c056
fix: edit mark popup bug
ArthurBeaulieu Jan 14, 2023
5b407f3
feat: mail html rendering
ArthurBeaulieu Jan 14, 2023
e18bc78
feat: improve touch events on modal
ArthurBeaulieu Jan 14, 2023
9f30f97
feat: improved pp square on landscape
ArthurBeaulieu Jan 14, 2023
cb7a436
fix(back): fix link in email templates
Asiberus Jan 14, 2023
a007611
build: configure docker env for production
Asiberus Jan 15, 2023
6a6cfba
chore(back): clean migrations
Asiberus Jan 15, 2023
eafbd2c
chore: clean settings and dockerfile
Asiberus Jan 15, 2023
87954d4
fix: upload pp bug when closing modal
ArthurBeaulieu Jan 15, 2023
2ea2691
Merge branch 'develop' of github.com:MesseBasseProduction/BeerCracker…
ArthurBeaulieu Jan 15, 2023
a40bd95
fix: improve mobile experience for image resizer
ArthurBeaulieu Jan 15, 2023
96f0755
fix: aside width in mobile
ArthurBeaulieu Jan 15, 2023
dcc3191
feat: update packagejson
ArthurBeaulieu Jan 15, 2023
e214912
wip: readme
ArthurBeaulieu Jan 16, 2023
c7128ef
fix(build): vsrf_trusted_origins in backend container
Asiberus Jan 16, 2023
89d1c9e
feat: startup help
ArthurBeaulieu Jan 16, 2023
f5f4d09
feat: add preference for startup help
ArthurBeaulieu Jan 16, 2023
a648d29
Update Kom.js
ArthurBeaulieu Jan 17, 2023
e3c9ee4
chore(build): change npm command for docker
Asiberus Jan 17, 2023
e0a7371
feat(back): add text and email body in email
Asiberus Jan 17, 2023
df0bbee
chore(front): run npm build
Asiberus Jan 17, 2023
0b3995b
fix(back): fix email text template name
Asiberus Jan 17, 2023
7674186
refactor(build): add static folder to staticfiles dir
Asiberus Jan 17, 2023
57f8329
fix(back): block logged in user to access welcome view
Asiberus Jan 17, 2023
d768ca2
Update StartupHelpModal.js
ArthurBeaulieu Jan 18, 2023
c548969
Update MapEnum.js
ArthurBeaulieu Jan 18, 2023
a489939
Update BeerCrackerzAuth.scss
ArthurBeaulieu Jan 18, 2023
14dffe1
Update BeerCrackerzAuth.js
ArthurBeaulieu Jan 18, 2023
b53a0a5
feat: create sh script to handle build and start
ArthurBeaulieu Jan 20, 2023
1548406
chore(back): change description maxlength to 500.
Asiberus Jan 20, 2023
e5cfe02
feat: proper quit in bc.sh
ArthurBeaulieu Jan 21, 2023
d329df9
wip: improving script
ArthurBeaulieu Jan 21, 2023
f582ef6
feat: improve auth style
ArthurBeaulieu Jan 21, 2023
92cef2d
Stopped tracking env
ArthurBeaulieu Jan 21, 2023
3d37771
fix: readmelink
ArthurBeaulieu Jan 21, 2023
6b2e297
fix: firefox fixtry
ArthurBeaulieu Jan 21, 2023
ff90815
feat: update hide svg
ArthurBeaulieu Jan 21, 2023
1a975cc
fix: icon size on firefox
ArthurBeaulieu Jan 21, 2023
b661387
fix: done fixing cmd on firefox
ArthurBeaulieu Jan 21, 2023
db02659
fix: firefox another one
ArthurBeaulieu Jan 21, 2023
994f8cb
feat: no-dash option in sh
ArthurBeaulieu Jan 21, 2023
b30c53a
Update README.md
ArthurBeaulieu Jan 23, 2023
2e556d1
feat: improve marker creation in auth page
ArthurBeaulieu Jan 23, 2023
e4cde33
Update index.html
ArthurBeaulieu Jan 23, 2023
30429b4
Update welcome.html
ArthurBeaulieu Jan 23, 2023
e728dca
Update index.html
ArthurBeaulieu Jan 23, 2023
7579530
fix: #2 margin in user profile modal
ArthurBeaulieu Jan 23, 2023
13c91bd
feat: proper popup and map click
ArthurBeaulieu Jan 23, 2023
3d2347e
feat: disable zoom on mobile
ArthurBeaulieu Jan 26, 2023
1b33f6c
fix: scale styling
ArthurBeaulieu Jan 28, 2023
80981bf
feat: hide on zoom slider
ArthurBeaulieu Jan 28, 2023
ea19c7b
Updated bc.sh
Jan 30, 2023
6a812e3
feat(build): Update option available
Jan 31, 2023
c847abc
feat: improve clustering
ArthurBeaulieu Feb 9, 2023
7249bad
feat: remove circles
ArthurBeaulieu Feb 18, 2023
8d36b1d
build: remove local conf
Asiberus Feb 22, 2023
e08cfd4
build: remove nginx_secret volume
Asiberus Feb 22, 2023
cde4080
fix: seet prod port to 8081
Asiberus Feb 22, 2023
45fd806
feat: add volume for nginx logs
Asiberus Feb 24, 2023
70e301f
fix: add server url env variable
Asiberus Feb 28, 2023
b8b051a
chore: remove git pull from updateApp script
Asiberus Feb 28, 2023
1127263
fix: orthograph in user creation mail
Asiberus Mar 1, 2023
a598007
Add a description when about option
Mar 2, 2023
b6e4cbf
forgot a carriage return
Mar 4, 2023
3388cc0
Update editConfIle method. Now update only var listed in for loop
Mar 4, 2023
2f26e21
feat: update min zoom on maps
ArthurBeaulieu Mar 13, 2023
2ae098f
feat: remove mail from login label
ArthurBeaulieu Apr 1, 2023
86ad81c
feat: restrict cluster radius
ArthurBeaulieu Apr 1, 2023
5addf3b
feat: remove clustering, test wip
ArthurBeaulieu Apr 1, 2023
ba34a19
feat: admin can edit spots ui
ArthurBeaulieu Apr 1, 2023
d586649
feat: handle app double click
ArthurBeaulieu Apr 1, 2023
42eb525
chore: add blank=True to user model
Asiberus Apr 1, 2023
5f14953
feat: add cliff, sea and lake to spot type
Asiberus Apr 1, 2023
f0bf36e
feat: css improvements
ArthurBeaulieu Apr 1, 2023
667b298
chore: run makemigrations
Asiberus Apr 1, 2023
cd4028d
feat: replace hide with filter icon
ArthurBeaulieu Apr 1, 2023
acaca22
chore: create point serializer
Asiberus Apr 1, 2023
aa95558
feat: center on mark from popup
ArthurBeaulieu Apr 1, 2023
dc2fc14
fix: admin edit all spots ui
ArthurBeaulieu Apr 1, 2023
bc1e368
fix: circle bug toggling markers
ArthurBeaulieu Apr 1, 2023
08258ae
fix: edit save from admin
ArthurBeaulieu Apr 1, 2023
92ee138
fix: edit save from admin v2
ArthurBeaulieu Apr 1, 2023
e3f496e
fix: edit save from admin v3
ArthurBeaulieu Apr 1, 2023
fadbab1
fix: login error msg
ArthurBeaulieu Apr 1, 2023
55b3802
feat: add spot, bar & shop in django admin
Asiberus Apr 1, 2023
e85d76a
chore: change server port
Asiberus Apr 1, 2023
4fa86f2
feat: it translation and help menu update
ArthurBeaulieu Apr 2, 2023
d79d5e4
chore: use env bash for bc script
Asiberus Apr 2, 2023
8b23108
chore: change server port
imadidev Apr 2, 2023
1cc992d
feat: remove labels
ArthurBeaulieu Apr 7, 2023
5fca111
feat: update help images
ArthurBeaulieu Apr 7, 2023
06403b7
chore(back): squash migrations
Asiberus Apr 8, 2023
69eaad1
chore(back): add creation date in spot, bar & shop in django admin
Asiberus Apr 8, 2023
d898096
fix: remove --volume option in bc.sh reset script
Asiberus Apr 8, 2023
69e659d
chore(back): remove squashed migrations
Asiberus Apr 8, 2023
0fca172
feat: add version number in nls files
ArthurBeaulieu Apr 9, 2023
e9db529
feat: improve credit text
ArthurBeaulieu Apr 9, 2023
1ce114f
fix: center on spot in auth
ArthurBeaulieu Apr 9, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat(front): create communication class for csrf header
ArthurBeaulieu committed Sep 15, 2022
commit 7359e415812ee32fdc3acf66778ade7da0906831
3 changes: 3 additions & 0 deletions front/src/BeerCrackerzAuth.js
Original file line number Diff line number Diff line change
@@ -5,6 +5,7 @@ import ZoomSlider from './js/ui/ZoomSlider.js';
import LangManager from './js/utils/LangManager.js';
import Notification from './js/ui/Notification.js';
import Utils from './js/utils/Utils.js';
import Kom from './js/utils/Kom.js';


class BeerCrackerzAuth extends MapHelper {
@@ -51,6 +52,8 @@ class BeerCrackerzAuth extends MapHelper {

this._aside = null;
this._isAsideExpanded = true;

this._kom = new Kom();
// The BeerCrackerz app is only initialized once nls are set up
// By default, the template contains the login aside, no need to fetch it
this._lang = new LangManager(
340 changes: 340 additions & 0 deletions front/src/js/utils/Kom.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,340 @@
class Kom {


/** @summary <h1>Server communication abstraction</h1>
* @author Arthur Beaulieu
* @since June 2020
* @description <blockquote>This class is the main object to deal with when requesting something from the server.<br>
* It handle all urls calls (<code>GET</code>, <code>POST</code>), treat responses or handle errors using
* <code>Promise</code>.<br>Because it uses <code>Promise</code>, success and errors are to be handled in the caller
* function, using <code>.then()</code> and <code>.catch()</code>. To properly deal with <code>POST</code> request,
* the session must contain a csrf token in cookies. Otherwise, those <code>POST</code> call may fail.</blockquote> */
constructor() {
/** @private
* @member {string} - User session CSRF token to use in POST request */
this._csrfToken = this._getCsrfCookie();
/** @private
* @member {array[]} - Array of HTTP headers to be used in HTTP calls */
this._headers = this._createRequestHeaders();
// Check that CSRF token exists and that headers are properly created
this._checkValidity();
}


/* --------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------- CLASS INIT UTILS ----------------------------------------------- */
/* --------------------------------------------------------------------------------------------------------------- */


/** @method
* @name _getCsrfCookie
* @private
* @memberof Kom
* @description <blockquote>Extract CSRF token value from client cookies and returns it as a string. Returns an empty
* string by default. This method is required to be called on construction.</blockquote>
* @return {string} - The CSRF token string */
_getCsrfCookie() {
if (document.cookie && document.cookie !== '') {
const cookies = document.cookie.split(';');
for (let i = 0; i < cookies.length; ++i) {
// Parse current cookie to extract its properties
const cookie = cookies[i].split('=');
if (cookie !== undefined && cookie[0].toLowerCase().includes('srf')) {
// Found a matching cookie for csrftoken value, return as decoded string
return decodeURIComponent(cookie[1]);
}
}
}
// Return empty string by default, POST calls may fail
return '';
}


/** @method
* @name _createRequestHeaders
* @private
* @memberof Kom
* @description <blockquote>Fills Kom <code>_headers</code> private member array, to use in HTTP requests later on.
* This method is required to be called on construction.</blockquote>
* @return {array[]} - The headers array, length 3, to be used in HTTP requests */
_createRequestHeaders() {
return [
['Content-Type', 'application/json; charset=UTF-8'],
['Accept', 'application/json'],
['X-XSRF-TOKEN', this._csrfToken]
];
}


/** @method
* @async
* @name _checkValidity
* @private
* @memberof Kom
* @description <blockquote>Check the Kom instance validity to ensure its properties validity.</blockquote> */
_checkValidity() {
if (this._csrfToken !== '') {
if (this._headers.length !== 3) {
console.error('F_KOM_HEADERS_ERROR');
}
} else {
console.error('F_KOM_NO_CSRF_TOKEN');
}
}


/* --------------------------------------------------------------------------------------------------------------- */
/* ------------------------------------------- PRIVATE METHODS ------------------------------------------------ */
/* --------------------------------------------------------------------------------------------------------------- */


/** @method
* @name _getErrorCodeFromHTTPStatus
* @private
* @memberof Kom
* @description <blockquote>This method is called whenever a server request didn't went well. In case a request (from
* any type) fails, its HTTP status code have to be handle in the method, so it returns an error code can be handled
* in the user interface (with notification, console or else).</blockquote>
* @param {number} code - The HTTP status code to handle, in supported ones from HttpStatusCode enumeration
* @return {string} The HTTP status as an error code */
_getErrorCodeFromHTTPStatus(code) {
if (code === 404) {
return 'B_KOM_NOT_FOUND';
} else if (code === 403) {
return 'B_KOM_ACCESS_FORBIDDEN';
} else if (code === 500) {
return 'B_KOM_INTERNAL_ERROR';
} else {
return `B_KOM_UNKNOWN_ERROR`;
}
}


/** @method
* @async
* @name _resolveAs
* @private
* @memberof Kom
* @description <blockquote>Generic tool method used by private methods on fetch responses to format output in the provided
* format. It must be either `json`, `text` or `raw`.</blockquote>
* @param {String} type - The type of resolution, can be `json`, `text` or `raw`
* @param {Object} response - The <code>fetch</code> response object
* @returns {Promise} The request <code>Promise</code>, format response as an object on resolve, as error code string on reject */
_resolveAs(type, response) {
return new Promise((resolve, reject) => {
if (response) {
if (type === 'raw') { // Raw are made in XMLHttpRequest and need special handling
if (response.status === 200) {
resolve(response.responseText);
} else {
reject(this._getErrorCodeFromHTTPStatus(response.status));
}
} else if (type === 'json' || type === 'text') { // Call are made using fetch API
if (response[type]) {
resolve(response[type]());
} else { // Fallback on standard error handling
reject(this._getErrorCodeFromHTTPStatus(response.status));
}
} else { // Resolution type doesn't exists
reject('F_KOM_UNSUPPORTED_TYPE');
}
} else {
reject('F_KOM_MISSING_ARGUMENT');
}
});
}


/** @method
* @async
* @name _resolveAsJSON
* @private
* @memberof Kom
* @description <blockquote>Tool method used by public methods on fetch responses to format output data as JSON to be
* read in JavaScript code as objects.</blockquote>
* @param {Object} response - The <code>fetch</code> response object
* @returns {Promise} The request <code>Promise</code>, format response as an object on resolve, as error code string on reject */
_resolveAsJSON(response) {
return this._resolveAs('json', response);
}


/** @method
* @async
* @name _resolveAsText
* @private
* @memberof Kom
* @description <blockquote>Tool method used by public methods on fetch responses to format output data as text to be
* read in JavaScript code as string (mostly to parse HTML templates).</blockquote>
* @param {Object} response - The <code>fetch</code> response object
* @returns {Promise} The request <code>Promise</code>, format response as a string on resolve, as error code string on reject */
_resolveAsText(response) {
return this._resolveAs('text', response);
}


/** @method
* @async
* @name _resolveAsRaw
* @private
* @memberof Kom
* @description <blockquote>Tool method used by XmlHTTPRequests to format server response as raw binary data.</blockquote>
* @param {Object} response - The <code>XmlHTTPRequest</code> response status object
* @returns {Promise} The request <code>Promise</code>, doesn't format response on resolve, send error code string on reject */
_resolveAsRaw(response) {
return this._resolveAs('raw', response);
}


_xhrCall(url, verb, data) {
return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest();
xhr.open(verb, url, true);
xhr.overrideMimeType('text/plain; charset=x-user-defined');
xhr.onreadystatechange = response => {
if (response.target.readyState === 4) { // Ready state changed has reach the response state
this._resolveAsRaw(response.target)
.then(resolve)
.catch(reject);
}
};
xhr.onerror = () => {
reject('F_KOM_XHR_ERROR');
};
xhr.send(data);
});
}


/* --------------------------------------------------------------------------------------------------------------- */
/* --------------------------------------- HTTP SERVER CALLS METHODS ------------------------------------------ */
/* --------------------------------------------------------------------------------------------------------------- */


/** @method
* @async
* @name get
* @public
* @memberof Kom
* @description <blockquote><code>GET</code> HTTP request using the fetch API.<br><code>resolve</code> returns the
* response as an <code>Object</code>.<br><code>reject</code> returns an error key as a <code>String</code>.
* It is meant to perform API call to access database through the user interface.</blockquote>
* @param {String} url - The <code>GET</code> url to fetch data from, in supported back URLs
* @returns {Promise} The request <code>Promise</code> */
get(url, resolution = this._resolveAsJSON.bind(this)) {
return new Promise((resolve, reject) => {
const options = {
method: 'GET',
headers: new Headers([this._headers[0]]) // Content type to JSON
};

fetch(url, options)
.then(resolution)
.then(resolve)
.catch(reject);
});
}


/** @method
* @async
* @name getText
* @public
* @memberof Kom
* @description <blockquote><code>GET</code> HTTP request using the fetch API.<br><code>resolve</code> returns the
* response as a <code>String</code>.<br><code>reject</code> returns an error key as a <code>String</code>. It is
* meant to perform API call to get HTML templates as string to be parsed as documents/documents fragments.</blockquote>
* @param {String} url - The <code>GET</code> url to fetch data from, in supported back URLs
* @returns {Promise} The request <code>Promise</code> */
getText(url) {
return this.get(url, this._resolveAsText.bind(this));
}


/** @method
* @async
* @name getRaw
* @public
* @memberof Kom
* @description <blockquote><code>GET</code> HTTP request using an <code>XMLHttpRequest</code>, with an override
* mime type hack to pass bytes through unprocessed.<br><code>resolve</code> returns the response as raw binary data.<br><code>reject</code>
* returns an error code as a <code>String</code>.</blockquote>
* @param {String} url - The url to fetch raw data from
* @returns {Promise} The request <code>Promise</code> */
getRaw(url) {
return new Promise((resolve, reject) => {
this._xhrCall(url, 'GET', null)
.then(resolve)
.catch(reject);
});
}


/** @method
* @async
* @name post
* @public
* @memberof Kom
* @description <blockquote><code>POST</code> HTTP request using the fetch API.<br>Beware that the given options
* object match the url expectations.<br><code>resolve</code>
* returns the response as an <code>Object</code>.<br><code>reject</code> returns an error key as a <code>String</code>.</blockquote>
* @param {String} url - The <code>POST</code> url to fetch data from
* @param {Object} data - The <code>JSON</code> object that contains <code>POST</code> parameters
* @returns {Promise} The request <code>Promise</code> */
post(url, data, resolution = this._resolveAsJSON.bind(this)) {
return new Promise((resolve, reject) => {
const options = {
method: 'POST',
headers: new Headers(this._headers), // POST needs all previously defined headers
body: JSON.stringify(data)
};

fetch(url, options)
.then(resolution)
.then(resolve)
.catch(reject);
});
}


/** @method
* @async
* @name postText
* @public
* @memberof Kom
* @description <blockquote><code>POST</code> HTTP request using the fetch API.<br>Beware that the given options
* object match the url expectations.<br><code>resolve</code>
* returns the response as a <code>String</code>.<br><code>reject</code> returns an error key as a <code>String</code>.</blockquote>
* @param {String} url - The <code>POST</code> url to fetch data from
* @param {Object} data - The <code>JSON</code> object that contains <code>POST</code> parameters
* @returns {Promise} The request <code>Promise</code> */
postText(url, data) {
return this.post(url, data, this._resolveAsText.bind(this));
}


/** @method
* @async
* @name postRaw
* @public
* @memberof Kom
* @description <blockquote><code>POST</code> HTTP request using the fetch API.<br>Beware that the given options
* object match the url expectations.<br><code>resolve</code>, with an override
* mime type hack to pass bytes through unprocessed.<br><code>resolve</code> returns the response as raw binary data.<br><code>reject</code>
* returns an error code as a <code>String</code>.</blockquote>
* @param {String} url - The url to fetch raw data from
* @param {Object} data - The <code>JSON</code> object that contains <code>POST</code> parameters
* @returns {Promise} The request <code>Promise</code> */
postRaw(url, data) {
return new Promise((resolve, reject) => {
this._xhrCall(url, 'POST', JSON.stringify(data))
.then(resolve)
.catch(reject);
});
}


}


export default Kom;
12 changes: 11 additions & 1 deletion static/dist/BeerCrackerzAuth.bundle.js

Large diffs are not rendered by default.