Skip to content

Commit

Permalink
Axios ES2017 (#4787)
Browse files Browse the repository at this point in the history
* Added AxiosHeaders class;

* Fixed README.md href;

* Fixed a potential bug with headers normalization;

* Fixed a potential bug with headers normalization;
Refactored accessor building routine;
Refactored default transforms;
Removed `normalizeHeaderName` helper;

* Added `Content-Length` accessor;
Added missed `has` accessor to TS types;

* Added `AxiosTransformStream` class;
Added progress capturing ability for node.js environment;
Added `maxRate` option to limit the data rate in node.js environment;
Refactored event handled by `onUploadProgress` && `onDownloadProgress` listeners in browser environment;
Added progress & data rate tests for the http adapter;
Added response stream aborting test;
Added a manual progress capture test for the browser;
Updated TS types;
Added TS tests;
Refactored request abort logic for the http adapter;
Added ability to abort the response stream;

* Remove `stream/promises` & `timers/promises` modules usage in tests;

* Use `abortcontroller-polyfill`;

* Fixed AxiosTransformStream dead-lock in legacy node versions;
Fixed CancelError emitting in streams;

* Reworked AxiosTransformStream internal logic to optimize memory consumption;
Added throwing an error if the request stream was silently destroying (without error) Refers to #3966;

* Treat the destruction of the request stream as a cancellation of the request;
Fixed tests;

* Emit `progress` event in the next tick;

* Initial refactoring;

* Refactored Mocha tests to use ESM;

* Refactored Karma tests to use rollup preprocessor & ESM;
Replaced grunt with gulp;
Improved dev scripts;
Added Babel for rollup build;

* Added default commonjs package export for Node build;
Added automatic contributors list generator for package.json;

Co-authored-by: Jay <jasonsaayman@gmail.com>
  • Loading branch information
DigitalBrainJS and jasonsaayman committed Jun 18, 2022
1 parent 1db715d commit bdf493c
Show file tree
Hide file tree
Showing 125 changed files with 26,432 additions and 23,261 deletions.
14 changes: 14 additions & 0 deletions .eslintrc.cjs
@@ -0,0 +1,14 @@
module.exports = {
"env": {
"browser": true,
"es2017": true,
"node": true
},
"extends": "eslint:recommended",
"parserOptions": {
"ecmaVersion": 2017,
"sourceType": "module"
},
"rules": {
}
}
151 changes: 0 additions & 151 deletions .eslintrc.js

This file was deleted.

101 changes: 0 additions & 101 deletions Gruntfile.js

This file was deleted.

2 changes: 1 addition & 1 deletion README.md
Expand Up @@ -47,7 +47,7 @@ Promise based HTTP client for the browser and node.js
- [FormData](#formdata)
- [🆕 Automatic serialization](#-automatic-serialization-to-formdata)
- [Files Posting](#files-posting)
- [HTML Form Posting](#html-form-posting-browser)
- [HTML Form Posting](#-html-form-posting-browser)
- [Semver](#semver)
- [Promises](#promises)
- [TypeScript](#typescript)
Expand Down
2 changes: 1 addition & 1 deletion bin/ssl_hotfix.js
@@ -1,4 +1,4 @@
const {spawn} = require('child_process');
import {spawn} from 'child_process';

const args = process.argv.slice(2);

Expand Down
4 changes: 2 additions & 2 deletions examples/get/server.js
@@ -1,4 +1,4 @@
var people = [
const people = [
{
"name": "Matt Zabriskie",
"github": "mzabriskie",
Expand All @@ -25,7 +25,7 @@ var people = [
}
];

module.exports = function (req, res) {
export default function (req, res) {
res.writeHead(200, {
'Content-Type': 'text/json'
});
Expand Down
4 changes: 2 additions & 2 deletions examples/post/server.js
@@ -1,5 +1,5 @@
module.exports = function (req, res) {
var data = '';
export default function (req, res) {
let data = '';

req.on('data', function (chunk) {
data += chunk;
Expand Down
2 changes: 1 addition & 1 deletion examples/postMultipartFormData/server.js
@@ -1,4 +1,4 @@
module.exports = function (req, res) {
export default function (req, res) {

req.on('data', function (chunk) {
});
Expand Down
37 changes: 21 additions & 16 deletions examples/server.js
@@ -1,18 +1,23 @@
var fs = require('fs');
var path = require('path');
var http = require('http');
var argv = require('minimist')(process.argv.slice(2));
var server;
var dirs;
import fs from 'fs';
import path from 'path';
import http from 'http';
import minimist from 'minimist';
import url from "url";
const argv = minimist(process.argv.slice(2));
let server;
let dirs;

const __filename = url.fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);

function listDirs(root) {
var files = fs.readdirSync(root);
var dirs = [];
const files = fs.readdirSync(root);
const dirs = [];

for (var i = 0, l = files.length; i < l; i++) {
var file = files[i];
for (let i = 0, l = files.length; i < l; i++) {
const file = files[i];
if (file[0] !== '.') {
var stat = fs.statSync(path.join(root, file));
const stat = fs.statSync(path.join(root, file));
if (stat.isDirectory()) {
dirs.push(file);
}
Expand All @@ -23,8 +28,8 @@ function listDirs(root) {
}

function getIndexTemplate() {
var links = dirs.map(function (dir) {
var url = '/' + dir;
const links = dirs.map(function (dir) {
const url = '/' + dir;
return '<li onclick="document.location=\'' + url + '\'"><a href="' + url + '">' + url + '</a></li>';
});

Expand Down Expand Up @@ -74,7 +79,7 @@ function pipeFileToResponse(res, file, type) {
dirs = listDirs(__dirname);

server = http.createServer(function (req, res) {
var url = req.url;
let url = req.url;

// Process axios itself
if (/axios\.min\.js$/.test(url)) {
Expand Down Expand Up @@ -106,7 +111,7 @@ server = http.createServer(function (req, res) {
}

// Format request /get -> /get/index.html
var parts = url.split('/');
const parts = url.split('/');
if (dirs.indexOf(parts[parts.length - 1]) > -1) {
url += '/index.html';
}
Expand Down Expand Up @@ -136,5 +141,5 @@ server = http.createServer(function (req, res) {
const PORT = argv.p || 3000;

server.listen(PORT, () => {
console.log(`Examples running on ${PORT}`);
console.log(`Examples running on ${PORT}`);
});
4 changes: 2 additions & 2 deletions examples/upload/server.js
@@ -1,5 +1,5 @@
module.exports = function (req, res) {
var data = '';
export default function (req, res) {
let data = '';

req.on('data', function (chunk) {
data += chunk;
Expand Down

0 comments on commit bdf493c

Please sign in to comment.