mirror of
https://github.com/dolthub/dolt.git
synced 2026-02-05 10:31:30 -06:00
@@ -17,8 +17,11 @@
|
||||
"watchify": "^3.6"
|
||||
},
|
||||
"scripts": {
|
||||
"start": "NOMS_SERVER=http://localhost:8000 watchify -o out.js -t babelify -t envify -v -d main.js",
|
||||
"build": "NOMS_SERVER=http://localhost:8000 NODE_ENV=production browserify main.js -t babelify -t envify > out.js",
|
||||
"start": "NOMS_SERVER=http://localhost:8000 watchify -o out.js -v -d main.js",
|
||||
"build": "NOMS_SERVER=http://localhost:8000 NODE_ENV=production browserify main.js > out.js",
|
||||
"test": "rm -f out.js && eslint *.js && flow"
|
||||
},
|
||||
"browserify": {
|
||||
"transform": ["babelify", "envify"]
|
||||
}
|
||||
}
|
||||
|
||||
@@ -3,8 +3,7 @@
|
||||
"main": "dist/noms.js",
|
||||
"dependencies": {
|
||||
"rusha": "^0.8.3",
|
||||
"text-encoding": "^0.5.2",
|
||||
"isomorphic-fetch": "^2.2.0"
|
||||
"text-encoding": "^0.5.2"
|
||||
},
|
||||
"devDependencies": {
|
||||
"babel": "~5.6.23",
|
||||
@@ -20,5 +19,8 @@
|
||||
"build": "babel src/ -d dist/",
|
||||
"pretest": "eslint src/ && flow src/",
|
||||
"test": "mocha --ui tdd --reporter dot --compilers js:babel/register src/"
|
||||
},
|
||||
"browser": {
|
||||
"./dist/fetch.js": "./dist/browser/fetch.js"
|
||||
}
|
||||
}
|
||||
|
||||
40
js/src/browser/fetch.js
Normal file
40
js/src/browser/fetch.js
Normal file
@@ -0,0 +1,40 @@
|
||||
/* @flow */
|
||||
|
||||
'use strict';
|
||||
|
||||
type FetchOptions = {
|
||||
method?: string,
|
||||
body?: any,
|
||||
headers?: {[key: string]: string}
|
||||
};
|
||||
|
||||
function fetch<T>(url: string, responseType: string, options: FetchOptions = {}) : Promise<T> {
|
||||
let xhr = new XMLHttpRequest();
|
||||
xhr.responseType = responseType;
|
||||
let method = options.method || 'GET';
|
||||
xhr.open(method, url, true);
|
||||
let p = new Promise((res, rej) => {
|
||||
xhr.onloadend = () => {
|
||||
if (xhr.status >= 200 && xhr.status < 300) {
|
||||
res(xhr.response);
|
||||
} else {
|
||||
rej(xhr.status);
|
||||
}
|
||||
};
|
||||
});
|
||||
if (options.headers) {
|
||||
for (let key in options.headers) {
|
||||
xhr.setRequestHeader(key, options.headers[key]);
|
||||
}
|
||||
}
|
||||
xhr.send(options.body);
|
||||
return p;
|
||||
}
|
||||
|
||||
export function fetchText(url: string, options: FetchOptions = {}) : Promise<string> {
|
||||
return fetch(url, 'text', options);
|
||||
}
|
||||
|
||||
export function fetchArrayBuffer(url: string, options: FetchOptions = {}) : Promise<ArrayBuffer> {
|
||||
return fetch(url, 'arraybuffer', options);
|
||||
}
|
||||
64
js/src/fetch.js
Normal file
64
js/src/fetch.js
Normal file
@@ -0,0 +1,64 @@
|
||||
/* @flow */
|
||||
|
||||
'use strict';
|
||||
|
||||
import {request} from 'http';
|
||||
import {parse} from 'url';
|
||||
|
||||
type FetchOptions = {
|
||||
method?: string,
|
||||
body?: any,
|
||||
headers?: {[key: string]: string}
|
||||
};
|
||||
|
||||
function fetch<T>(url: string, f: (buf: Buffer) => T, options: FetchOptions = {}) : Promise<T> {
|
||||
let opts: any = parse(url);
|
||||
opts.method = options.method || 'GET';
|
||||
if (options.headers) {
|
||||
opts.headers = options.headers;
|
||||
}
|
||||
return new Promise((resolve, reject) => {
|
||||
let req = request(opts, res => {
|
||||
if (res.statusCode < 200 || res.statusCode >= 300) {
|
||||
reject(res.statusCode);
|
||||
return;
|
||||
}
|
||||
let buf = new Buffer(0);
|
||||
res.on('data', (chunk: Buffer) => {
|
||||
buf = Buffer.concat([buf, chunk]);
|
||||
});
|
||||
res.on('end', () => {
|
||||
resolve(f(buf));
|
||||
});
|
||||
});
|
||||
req.on('error', err => {
|
||||
reject(err);
|
||||
});
|
||||
if (options.body) {
|
||||
req.write(options.body);
|
||||
}
|
||||
req.end();
|
||||
});
|
||||
}
|
||||
|
||||
function bufferToArrayBuffer(buf: Buffer) : ArrayBuffer {
|
||||
let ab = new ArrayBuffer(buf.length);
|
||||
let view = new Uint8Array(ab);
|
||||
for (let i = 0; i < buf.length; i++) {
|
||||
view[i] = buf[i];
|
||||
}
|
||||
return ab;
|
||||
}
|
||||
|
||||
|
||||
function bufferToString(buf: Buffer) : string {
|
||||
return buf.toString();
|
||||
}
|
||||
|
||||
export function fetchText(url: string, options: FetchOptions = {}) : Promise<string> {
|
||||
return fetch(url, bufferToString, options);
|
||||
}
|
||||
|
||||
export function fetchArrayBuffer(url: string, options: FetchOptions = {}) : Promise<ArrayBuffer> {
|
||||
return fetch(url, bufferToArrayBuffer, options);
|
||||
}
|
||||
@@ -3,26 +3,15 @@
|
||||
'use strict';
|
||||
|
||||
import Chunk from './chunk.js';
|
||||
import fetch from 'isomorphic-fetch';
|
||||
import Ref from './ref.js';
|
||||
import {deserialize} from './chunk_serializer.js';
|
||||
import {invariant} from './assert.js';
|
||||
import {fetchArrayBuffer, fetchText} from './fetch.js';
|
||||
|
||||
type ReadRequest = {
|
||||
resolve: (c: Chunk) => void,
|
||||
reject: (e: Error) => void
|
||||
};
|
||||
|
||||
function blobToBuffer(blob: Blob): Promise<ArrayBuffer> {
|
||||
return new Promise((resolve) => {
|
||||
let reader = new FileReader();
|
||||
reader.addEventListener('loadend', () => {
|
||||
resolve(reader.result);
|
||||
});
|
||||
reader.readAsArrayBuffer(blob);
|
||||
});
|
||||
}
|
||||
|
||||
export default class HttpStore {
|
||||
_rpc: {
|
||||
getRefs: string,
|
||||
@@ -49,8 +38,7 @@ export default class HttpStore {
|
||||
}
|
||||
|
||||
async getRoot(): Promise<Ref> {
|
||||
let r = await fetch(this._rpc.root);
|
||||
let refStr = await r.text();
|
||||
let refStr = await fetchText(this._rpc.root);
|
||||
return Ref.parse(refStr);
|
||||
}
|
||||
|
||||
@@ -87,7 +75,7 @@ export default class HttpStore {
|
||||
let body = refStrs.map(r => 'ref=' + r).join('&');
|
||||
|
||||
try {
|
||||
let response = await fetch(this._rpc.getRefs, {
|
||||
let buffer = await fetchArrayBuffer(this._rpc.getRefs, {
|
||||
method: 'post',
|
||||
body: body,
|
||||
headers: {
|
||||
@@ -95,10 +83,6 @@ export default class HttpStore {
|
||||
}
|
||||
});
|
||||
|
||||
invariant(response.status === 200, 'Buffered read failed: ' + response.status);
|
||||
|
||||
let blob = await response.blob();
|
||||
let buffer = await blobToBuffer(blob);
|
||||
let chunks = deserialize(buffer);
|
||||
|
||||
// Return success
|
||||
|
||||
Reference in New Issue
Block a user