From a3c25e4258a91a9d75afb4430c605f7373916aca Mon Sep 17 00:00:00 2001 From: Greger Lindblom Date: Wed, 4 Oct 2017 18:30:28 +0200 Subject: [PATCH 1/3] make tests run on windows Uses cross-env in 'package.json' to set environment variables on windows. Prefixes environment variables with 'AVANZA_' to avoid using already set 'USERNAME' variable on windows. dotenv can't override already set variables. --- .env-example | 12 +- package-lock.json | 953 ++---------------------------- package.json | 5 +- scripts/generate-documentation.js | 16 +- tests/index.test.js | 12 +- tests/orders.test.js | 14 +- 6 files changed, 76 insertions(+), 936 deletions(-) diff --git a/.env-example b/.env-example index 000efe1..3a3b998 100644 --- a/.env-example +++ b/.env-example @@ -1,5 +1,7 @@ -USERNAME= -PASSWORD= -ACCOUNT= -STOCK= -WATCHLIST= +AVANZA_USERNAME= +AVANZA_PASSWORD= +AVANZA_ACCOUNT= +AVANZA_STOCK=5479 +AVANZA_STOCK2=5269 +AVANZA_WATCHLIST= +#AVANZA_USER_AGENT= diff --git a/package-lock.json b/package-lock.json index c227435..081d444 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "avanza", - "version": "1.0.0", + "version": "1.1.0", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -1681,7 +1681,6 @@ "requires": { "anymatch": "1.3.0", "async-each": "1.0.1", - "fsevents": "1.1.2", "glob-parent": "2.0.0", "inherits": "2.0.3", "is-binary-path": "1.0.1", @@ -2013,6 +2012,35 @@ "capture-stack-trace": "1.0.0" } }, + "cross-env": { + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/cross-env/-/cross-env-5.0.5.tgz", + "integrity": "sha1-Q4PTZNlmCHPdGFs5ivO/717//vM=", + "dev": true, + "requires": { + "cross-spawn": "5.1.0", + "is-windows": "1.0.1" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", + "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", + "dev": true, + "requires": { + "lru-cache": "4.1.1", + "shebang-command": "1.2.0", + "which": "1.2.14" + } + }, + "is-windows": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.1.tgz", + "integrity": "sha1-MQ23D3QtJZoWo2kgK1GvhCMzENk=", + "dev": true + } + } + }, "cross-spawn": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-4.0.2.tgz", @@ -2883,905 +2911,6 @@ "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", "dev": true }, - "fsevents": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.2.tgz", - "integrity": "sha512-Sn44E5wQW4bTHXvQmvSHwqbuiXtduD6Rrjm2ZtUEGbyrig+nUH3t/QD4M4/ZXViY556TBpRgZkHLDx3JxPwxiw==", - "dev": true, - "optional": true, - "requires": { - "nan": "2.6.2", - "node-pre-gyp": "0.6.36" - }, - "dependencies": { - "abbrev": { - "version": "1.1.0", - "bundled": true, - "dev": true, - "optional": true - }, - "ajv": { - "version": "4.11.8", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "co": "4.6.0", - "json-stable-stringify": "1.0.1" - } - }, - "ansi-regex": { - "version": "2.1.1", - "bundled": true, - "dev": true - }, - "aproba": { - "version": "1.1.1", - "bundled": true, - "dev": true, - "optional": true - }, - "are-we-there-yet": { - "version": "1.1.4", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "delegates": "1.0.0", - "readable-stream": "2.2.9" - } - }, - "asn1": { - "version": "0.2.3", - "bundled": true, - "dev": true, - "optional": true - }, - "assert-plus": { - "version": "0.2.0", - "bundled": true, - "dev": true, - "optional": true - }, - "asynckit": { - "version": "0.4.0", - "bundled": true, - "dev": true, - "optional": true - }, - "aws-sign2": { - "version": "0.6.0", - "bundled": true, - "dev": true, - "optional": true - }, - "aws4": { - "version": "1.6.0", - "bundled": true, - "dev": true, - "optional": true - }, - "balanced-match": { - "version": "0.4.2", - "bundled": true, - "dev": true - }, - "bcrypt-pbkdf": { - "version": "1.0.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "tweetnacl": "0.14.5" - } - }, - "block-stream": { - "version": "0.0.9", - "bundled": true, - "dev": true, - "requires": { - "inherits": "2.0.3" - } - }, - "boom": { - "version": "2.10.1", - "bundled": true, - "dev": true, - "requires": { - "hoek": "2.16.3" - } - }, - "brace-expansion": { - "version": "1.1.7", - "bundled": true, - "dev": true, - "requires": { - "balanced-match": "0.4.2", - "concat-map": "0.0.1" - } - }, - "buffer-shims": { - "version": "1.0.0", - "bundled": true, - "dev": true - }, - "caseless": { - "version": "0.12.0", - "bundled": true, - "dev": true, - "optional": true - }, - "co": { - "version": "4.6.0", - "bundled": true, - "dev": true, - "optional": true - }, - "code-point-at": { - "version": "1.1.0", - "bundled": true, - "dev": true - }, - "combined-stream": { - "version": "1.0.5", - "bundled": true, - "dev": true, - "requires": { - "delayed-stream": "1.0.0" - } - }, - "concat-map": { - "version": "0.0.1", - "bundled": true, - "dev": true - }, - "console-control-strings": { - "version": "1.1.0", - "bundled": true, - "dev": true - }, - "core-util-is": { - "version": "1.0.2", - "bundled": true, - "dev": true - }, - "cryptiles": { - "version": "2.0.5", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "boom": "2.10.1" - } - }, - "dashdash": { - "version": "1.14.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - } - } - }, - "debug": { - "version": "2.6.8", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "ms": "2.0.0" - } - }, - "deep-extend": { - "version": "0.4.2", - "bundled": true, - "dev": true, - "optional": true - }, - "delayed-stream": { - "version": "1.0.0", - "bundled": true, - "dev": true - }, - "delegates": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - }, - "ecc-jsbn": { - "version": "0.1.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "jsbn": "0.1.1" - } - }, - "extend": { - "version": "3.0.1", - "bundled": true, - "dev": true, - "optional": true - }, - "extsprintf": { - "version": "1.0.2", - "bundled": true, - "dev": true - }, - "forever-agent": { - "version": "0.6.1", - "bundled": true, - "dev": true, - "optional": true - }, - "form-data": { - "version": "2.1.4", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "asynckit": "0.4.0", - "combined-stream": "1.0.5", - "mime-types": "2.1.15" - } - }, - "fs.realpath": { - "version": "1.0.0", - "bundled": true, - "dev": true - }, - "fstream": { - "version": "1.0.11", - "bundled": true, - "dev": true, - "requires": { - "graceful-fs": "4.1.11", - "inherits": "2.0.3", - "mkdirp": "0.5.1", - "rimraf": "2.6.1" - } - }, - "fstream-ignore": { - "version": "1.0.5", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "fstream": "1.0.11", - "inherits": "2.0.3", - "minimatch": "3.0.4" - } - }, - "gauge": { - "version": "2.7.4", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "aproba": "1.1.1", - "console-control-strings": "1.1.0", - "has-unicode": "2.0.1", - "object-assign": "4.1.1", - "signal-exit": "3.0.2", - "string-width": "1.0.2", - "strip-ansi": "3.0.1", - "wide-align": "1.1.2" - } - }, - "getpass": { - "version": "0.1.7", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - } - } - }, - "glob": { - "version": "7.1.2", - "bundled": true, - "dev": true, - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, - "graceful-fs": { - "version": "4.1.11", - "bundled": true, - "dev": true - }, - "har-schema": { - "version": "1.0.5", - "bundled": true, - "dev": true, - "optional": true - }, - "har-validator": { - "version": "4.2.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "ajv": "4.11.8", - "har-schema": "1.0.5" - } - }, - "has-unicode": { - "version": "2.0.1", - "bundled": true, - "dev": true, - "optional": true - }, - "hawk": { - "version": "3.1.3", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "boom": "2.10.1", - "cryptiles": "2.0.5", - "hoek": "2.16.3", - "sntp": "1.0.9" - } - }, - "hoek": { - "version": "2.16.3", - "bundled": true, - "dev": true - }, - "http-signature": { - "version": "1.1.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "assert-plus": "0.2.0", - "jsprim": "1.4.0", - "sshpk": "1.13.0" - } - }, - "inflight": { - "version": "1.0.6", - "bundled": true, - "dev": true, - "requires": { - "once": "1.4.0", - "wrappy": "1.0.2" - } - }, - "inherits": { - "version": "2.0.3", - "bundled": true, - "dev": true - }, - "ini": { - "version": "1.3.4", - "bundled": true, - "dev": true, - "optional": true - }, - "is-fullwidth-code-point": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "requires": { - "number-is-nan": "1.0.1" - } - }, - "is-typedarray": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - }, - "isarray": { - "version": "1.0.0", - "bundled": true, - "dev": true - }, - "isstream": { - "version": "0.1.2", - "bundled": true, - "dev": true, - "optional": true - }, - "jodid25519": { - "version": "1.0.2", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "jsbn": "0.1.1" - } - }, - "jsbn": { - "version": "0.1.1", - "bundled": true, - "dev": true, - "optional": true - }, - "json-schema": { - "version": "0.2.3", - "bundled": true, - "dev": true, - "optional": true - }, - "json-stable-stringify": { - "version": "1.0.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "jsonify": "0.0.0" - } - }, - "json-stringify-safe": { - "version": "5.0.1", - "bundled": true, - "dev": true, - "optional": true - }, - "jsonify": { - "version": "0.0.0", - "bundled": true, - "dev": true, - "optional": true - }, - "jsprim": { - "version": "1.4.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "assert-plus": "1.0.0", - "extsprintf": "1.0.2", - "json-schema": "0.2.3", - "verror": "1.3.6" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - } - } - }, - "mime-db": { - "version": "1.27.0", - "bundled": true, - "dev": true - }, - "mime-types": { - "version": "2.1.15", - "bundled": true, - "dev": true, - "requires": { - "mime-db": "1.27.0" - } - }, - "minimatch": { - "version": "3.0.4", - "bundled": true, - "dev": true, - "requires": { - "brace-expansion": "1.1.7" - } - }, - "minimist": { - "version": "0.0.8", - "bundled": true, - "dev": true - }, - "mkdirp": { - "version": "0.5.1", - "bundled": true, - "dev": true, - "requires": { - "minimist": "0.0.8" - } - }, - "ms": { - "version": "2.0.0", - "bundled": true, - "dev": true, - "optional": true - }, - "node-pre-gyp": { - "version": "0.6.36", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "mkdirp": "0.5.1", - "nopt": "4.0.1", - "npmlog": "4.1.0", - "rc": "1.2.1", - "request": "2.81.0", - "rimraf": "2.6.1", - "semver": "5.3.0", - "tar": "2.2.1", - "tar-pack": "3.4.0" - } - }, - "nopt": { - "version": "4.0.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "abbrev": "1.1.0", - "osenv": "0.1.4" - } - }, - "npmlog": { - "version": "4.1.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "are-we-there-yet": "1.1.4", - "console-control-strings": "1.1.0", - "gauge": "2.7.4", - "set-blocking": "2.0.0" - } - }, - "number-is-nan": { - "version": "1.0.1", - "bundled": true, - "dev": true - }, - "oauth-sign": { - "version": "0.8.2", - "bundled": true, - "dev": true, - "optional": true - }, - "object-assign": { - "version": "4.1.1", - "bundled": true, - "dev": true, - "optional": true - }, - "once": { - "version": "1.4.0", - "bundled": true, - "dev": true, - "requires": { - "wrappy": "1.0.2" - } - }, - "os-homedir": { - "version": "1.0.2", - "bundled": true, - "dev": true, - "optional": true - }, - "os-tmpdir": { - "version": "1.0.2", - "bundled": true, - "dev": true, - "optional": true - }, - "osenv": { - "version": "0.1.4", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "os-homedir": "1.0.2", - "os-tmpdir": "1.0.2" - } - }, - "path-is-absolute": { - "version": "1.0.1", - "bundled": true, - "dev": true - }, - "performance-now": { - "version": "0.2.0", - "bundled": true, - "dev": true, - "optional": true - }, - "process-nextick-args": { - "version": "1.0.7", - "bundled": true, - "dev": true - }, - "punycode": { - "version": "1.4.1", - "bundled": true, - "dev": true, - "optional": true - }, - "qs": { - "version": "6.4.0", - "bundled": true, - "dev": true, - "optional": true - }, - "rc": { - "version": "1.2.1", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "deep-extend": "0.4.2", - "ini": "1.3.4", - "minimist": "1.2.0", - "strip-json-comments": "2.0.1" - }, - "dependencies": { - "minimist": { - "version": "1.2.0", - "bundled": true, - "dev": true, - "optional": true - } - } - }, - "readable-stream": { - "version": "2.2.9", - "bundled": true, - "dev": true, - "requires": { - "buffer-shims": "1.0.0", - "core-util-is": "1.0.2", - "inherits": "2.0.3", - "isarray": "1.0.0", - "process-nextick-args": "1.0.7", - "string_decoder": "1.0.1", - "util-deprecate": "1.0.2" - } - }, - "request": { - "version": "2.81.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "aws-sign2": "0.6.0", - "aws4": "1.6.0", - "caseless": "0.12.0", - "combined-stream": "1.0.5", - "extend": "3.0.1", - "forever-agent": "0.6.1", - "form-data": "2.1.4", - "har-validator": "4.2.1", - "hawk": "3.1.3", - "http-signature": "1.1.1", - "is-typedarray": "1.0.0", - "isstream": "0.1.2", - "json-stringify-safe": "5.0.1", - "mime-types": "2.1.15", - "oauth-sign": "0.8.2", - "performance-now": "0.2.0", - "qs": "6.4.0", - "safe-buffer": "5.0.1", - "stringstream": "0.0.5", - "tough-cookie": "2.3.2", - "tunnel-agent": "0.6.0", - "uuid": "3.0.1" - } - }, - "rimraf": { - "version": "2.6.1", - "bundled": true, - "dev": true, - "requires": { - "glob": "7.1.2" - } - }, - "safe-buffer": { - "version": "5.0.1", - "bundled": true, - "dev": true - }, - "semver": { - "version": "5.3.0", - "bundled": true, - "dev": true, - "optional": true - }, - "set-blocking": { - "version": "2.0.0", - "bundled": true, - "dev": true, - "optional": true - }, - "signal-exit": { - "version": "3.0.2", - "bundled": true, - "dev": true, - "optional": true - }, - "sntp": { - "version": "1.0.9", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "hoek": "2.16.3" - } - }, - "sshpk": { - "version": "1.13.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "asn1": "0.2.3", - "assert-plus": "1.0.0", - "bcrypt-pbkdf": "1.0.1", - "dashdash": "1.14.1", - "ecc-jsbn": "0.1.1", - "getpass": "0.1.7", - "jodid25519": "1.0.2", - "jsbn": "0.1.1", - "tweetnacl": "0.14.5" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "bundled": true, - "dev": true, - "optional": true - } - } - }, - "string_decoder": { - "version": "1.0.1", - "bundled": true, - "dev": true, - "requires": { - "safe-buffer": "5.0.1" - } - }, - "string-width": { - "version": "1.0.2", - "bundled": true, - "dev": true, - "requires": { - "code-point-at": "1.1.0", - "is-fullwidth-code-point": "1.0.0", - "strip-ansi": "3.0.1" - } - }, - "stringstream": { - "version": "0.0.5", - "bundled": true, - "dev": true, - "optional": true - }, - "strip-ansi": { - "version": "3.0.1", - "bundled": true, - "dev": true, - "requires": { - "ansi-regex": "2.1.1" - } - }, - "strip-json-comments": { - "version": "2.0.1", - "bundled": true, - "dev": true, - "optional": true - }, - "tar": { - "version": "2.2.1", - "bundled": true, - "dev": true, - "requires": { - "block-stream": "0.0.9", - "fstream": "1.0.11", - "inherits": "2.0.3" - } - }, - "tar-pack": { - "version": "3.4.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "debug": "2.6.8", - "fstream": "1.0.11", - "fstream-ignore": "1.0.5", - "once": "1.4.0", - "readable-stream": "2.2.9", - "rimraf": "2.6.1", - "tar": "2.2.1", - "uid-number": "0.0.6" - } - }, - "tough-cookie": { - "version": "2.3.2", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "punycode": "1.4.1" - } - }, - "tunnel-agent": { - "version": "0.6.0", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "safe-buffer": "5.0.1" - } - }, - "tweetnacl": { - "version": "0.14.5", - "bundled": true, - "dev": true, - "optional": true - }, - "uid-number": { - "version": "0.0.6", - "bundled": true, - "dev": true, - "optional": true - }, - "util-deprecate": { - "version": "1.0.2", - "bundled": true, - "dev": true - }, - "uuid": { - "version": "3.0.1", - "bundled": true, - "dev": true, - "optional": true - }, - "verror": { - "version": "1.3.6", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "extsprintf": "1.0.2" - } - }, - "wide-align": { - "version": "1.1.2", - "bundled": true, - "dev": true, - "optional": true, - "requires": { - "string-width": "1.0.2" - } - }, - "wrappy": { - "version": "1.0.2", - "bundled": true, - "dev": true - } - } - }, "function-bind": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.0.tgz", @@ -5428,13 +4557,6 @@ "integrity": "sha1-j7+rsKmKJT0xhDMfno3rc3L6xsA=", "dev": true }, - "nan": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", - "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=", - "dev": true, - "optional": true - }, "native-promise-only": { "version": "0.8.1", "resolved": "https://registry.npmjs.org/native-promise-only/-/native-promise-only-0.8.1.tgz", @@ -6519,6 +5641,21 @@ "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", "dev": true }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "dev": true, + "requires": { + "shebang-regex": "1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", + "dev": true + }, "shelljs": { "version": "0.7.8", "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.7.8.tgz", diff --git a/package.json b/package.json index 45fa533..90c15e3 100644 --- a/package.json +++ b/package.json @@ -4,8 +4,8 @@ "description": "A wrapper for the unofficial Avanza API", "main": "dist/index.js", "scripts": { - "start": "NODE_ENV=production babel lib -d dist", - "test": "npm start && NODE_ENV=test NODE_PATH=lib ava tests/**/*.test.js", + "start": "cross-env NODE_ENV=production babel lib -d dist", + "test": "npm start && cross-env NODE_ENV=test NODE_PATH=lib ava tests/**/*.test.js", "lint": "eslint lib/**/*", "docs": "node scripts/generate-documentation.js", "prepublishOnly": "npm run lint && npm run test" @@ -30,6 +30,7 @@ "ava": "^0.20.0", "babel-cli": "^6.24.0", "babel-preset-env": "^1.6.0", + "cross-env": "^5.0.5", "documentation": "^4.0.0-rc.1", "dotenv": "^2.0.0", "eslint": "^3.9.1", diff --git a/scripts/generate-documentation.js b/scripts/generate-documentation.js index 0fd8410..f7c4a92 100644 --- a/scripts/generate-documentation.js +++ b/scripts/generate-documentation.js @@ -10,14 +10,14 @@ const filename = path.join(process.cwd(), 'lib', 'index.js') const calls = { getPositions: () => avanza.getPositions(), getOverview: () => avanza.getOverview(), - getAccountOverview: () => avanza.getAccountOverview(process.env.ACCOUNT), + getAccountOverview: () => avanza.getAccountOverview(process.env.AVANZA_ACCOUNT), getDealsAndOrders: () => avanza.getDealsAndOrders(), - getTransactions: () => avanza.getTransactions(process.env.ACCOUNT, { from: '2017-01-01', to: '2019-01-01' }), + getTransactions: () => avanza.getTransactions(process.env.AVANZA_ACCOUNT, { from: '2017-01-01', to: '2019-01-01' }), getWatchlists: () => avanza.getWatchlists(), - getInstrument: () => avanza.getInstrument(Avanza.STOCK, process.env.STOCK), - getOrderbook: () => avanza.getOrderbook(Avanza.STOCK, process.env.STOCK), - getOrderbooks: () => avanza.getOrderbooks([process.env.STOCK, process.env.STOCK2]), - getChartdata: () => avanza.getChartdata(process.env.STOCK, Avanza.ONE_MONTH), + getInstrument: () => avanza.getInstrument(Avanza.STOCK, process.env.AVANZA_STOCK), + getOrderbook: () => avanza.getOrderbook(Avanza.STOCK, process.env.AVANZA_STOCK), + getOrderbooks: () => avanza.getOrderbooks([process.env.AVANZA_STOCK, process.env.AVANZA_STOCK2]), + getChartdata: () => avanza.getChartdata(process.env.AVANZA_STOCK, Avanza.ONE_MONTH), getInspirationLists: () => avanza.getInspirationLists(), getInspirationList: () => avanza.getInspirationList(Avanza.HIGHEST_RATED_FUNDS), search: () => avanza.search('om') @@ -169,6 +169,6 @@ async function buildMarkdown() { * Run the generator */ avanza.authenticate({ - username: process.env.USERNAME, - password: process.env.PASSWORD + username: process.env.AVANZA_USERNAME, + password: process.env.AVANZA_PASSWORD }).then(buildMarkdown) diff --git a/tests/index.test.js b/tests/index.test.js index 57a1a53..dd64d59 100644 --- a/tests/index.test.js +++ b/tests/index.test.js @@ -14,8 +14,8 @@ test.beforeEach((t) => { test.serial('authenticate()', async (t) => { const res = await t.context.avanza.authenticate({ - username: process.env.USERNAME, - password: process.env.PASSWORD + username: process.env.AVANZA_USERNAME, + password: process.env.AVANZA_PASSWORD }) t.is(typeof res.authenticationSession, 'string', 'authenticationSession is received') t.is(typeof res.pushSubscriptionId, 'string', 'pusbSubscriptionId is received') @@ -148,8 +148,8 @@ test('deleteOrder()', async (t) => { test.cb('subscribe()', (t) => { const { avanza } = t.context avanza.authenticate({ - username: process.env.USERNAME, - password: process.env.PASSWORD + username: process.env.AVANZA_USERNAME, + password: process.env.AVANZA_PASSWORD }).then(() => { setTimeout(() => { if (avanza._socketClientId) { @@ -167,8 +167,8 @@ test.cb('multiple subscribe()', (t) => { t.plan(2) const { avanza } = t.context avanza.authenticate({ - username: process.env.USERNAME, - password: process.env.PASSWORD + username: process.env.AVANZA_USERNAME, + password: process.env.AVANZA_PASSWORD }).then(() => { let received = false avanza.subscribe(Avanza.QUOTES, '5269', () => { diff --git a/tests/orders.test.js b/tests/orders.test.js index 42f91f9..48de9e4 100644 --- a/tests/orders.test.js +++ b/tests/orders.test.js @@ -9,8 +9,8 @@ const avanza = new Avanza() test.before(async () => { await avanza.authenticate({ - username: process.env.USERNAME, - password: process.env.PASSWORD + username: process.env.AVANZA_USERNAME, + password: process.env.AVANZA_PASSWORD }) }) @@ -31,8 +31,8 @@ test('place valid order, edit it and delete it', async (t) => { */ try { actual = await avanza.placeOrder({ - accountId: process.env.ACCOUNT, - orderbookId: process.env.STOCK, + accountId: process.env.AVANZA_ACCOUNT, + orderbookId: process.env.AVANZA_STOCK, orderType: Avanza.BUY, price: 35, validUntil: dateString, @@ -62,7 +62,7 @@ test('place valid order, edit it and delete it', async (t) => { */ await new Promise(r => setTimeout(r, 1000)) try { - await avanza.getOrder(Avanza.STOCK, process.env.ACCOUNT, orderId) + await avanza.getOrder(Avanza.STOCK, process.env.AVANZA_ACCOUNT, orderId) } catch (e) { console.log(e) t.fail(e.statusMessage) @@ -76,7 +76,7 @@ test('place valid order, edit it and delete it', async (t) => { await new Promise(r => setTimeout(r, 1000)) try { actual = await avanza.editOrder(Avanza.STOCK, orderId, { - accountId: process.env.ACCOUNT, + accountId: process.env.AVANZA_ACCOUNT, volume: 11, price: 35, validUntil: dateString @@ -102,7 +102,7 @@ test('place valid order, edit it and delete it', async (t) => { */ await new Promise(r => setTimeout(r, 1000)) try { - actual = await avanza.deleteOrder(process.env.ACCOUNT, orderId) + actual = await avanza.deleteOrder(process.env.AVANZA_ACCOUNT, orderId) expected = { messages: [''], orderId, From b17aa4b6a039b94d31b5ea446f3b90780f94b0fa Mon Sep 17 00:00:00 2001 From: Greger Lindblom Date: Wed, 4 Oct 2017 19:17:50 +0200 Subject: [PATCH 2/3] change addToWatchlist() request method The endpoint 'WATCHLISTS_ADD_PATH' only supports 'PUT' and 'DELETE'. --- lib/index.js | 2 +- tests/index.test.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/index.js b/lib/index.js index c88a856..e34ef29 100644 --- a/lib/index.js +++ b/lib/index.js @@ -383,7 +383,7 @@ class Avanza extends EventEmitter { const path = constants.paths.WATCHLISTS_ADD_PATH .replace('{0}', watchlistId) .replace('{1}', instrumentId) - return this.call('GET', path) + return this.call('PUT', path) } /** diff --git a/tests/index.test.js b/tests/index.test.js index dd64d59..91380ef 100644 --- a/tests/index.test.js +++ b/tests/index.test.js @@ -64,7 +64,7 @@ test('addToWatchlist()', async (t) => { .replace('{0}', '54321') const actual = t.context.call.args[0] - const expected = ['GET', expectedPath] + const expected = ['PUT', expectedPath] t.deepEqual(actual, expected) }) From 0cea00212b0860ce971a9f8b37a3a8defcf81e1a Mon Sep 17 00:00:00 2001 From: Greger Lindblom Date: Wed, 4 Oct 2017 20:17:30 +0200 Subject: [PATCH 3/3] add removeFromWatchlist() function Take advantage of the functionality the endpoint 'WATCHLISTS_ADD_PATH' exposes. Rename 'WATCHLISTS_ADD_PATH' to 'WATCHLISTS_ADD_DELETE_PATH' to better reflect the supported methods. --- API.md | 27 +++++++++++++++++++++++++++ lib/constants.js | 40 ++++++++++++++++++++-------------------- lib/index.js | 15 ++++++++++++++- tests/index.test.js | 14 +++++++++++++- 4 files changed, 74 insertions(+), 22 deletions(-) diff --git a/API.md b/API.md index b3dc374..1523c81 100644 --- a/API.md +++ b/API.md @@ -18,6 +18,7 @@ - [getTransactions](#gettransactions) - [getWatchlists](#getwatchlists) - [addToWatchlist](#addtowatchlist) + - [removeFromWatchlist](#removefromwatchlist) - [getInstrument](#getinstrument) - [getOrderbook](#getorderbook) - [getOrderbooks](#getorderbooks) @@ -345,6 +346,7 @@ Get all transactions of an account. | Property | Type | Note | | :----------------- | :----- | ---- | | `account` | Object | | +| `amount` | Number | | | `currency` | String | | | `description` | String | | | `id` | String | | @@ -404,6 +406,15 @@ Add an instrument to the watchlist. - `instrumentId` **[String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)** The ID of the instrument to add. - `watchlistId` **[String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)** The ID of the watchlist to add the instrument to. +### removeFromWatchlist + +Remove an instrument from the watchlist. + +**Parameters** + +- `instrumentId` **[String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)** The ID of the instrument to remove. +- `watchlistId` **[String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)** The ID of the watchlist to remove the instrument from. + ### getInstrument Get instrument information. @@ -539,6 +550,7 @@ Get orderbook information. | `orderbook` | Object | | | `orderDepthLevels` | Array | | | `orderDepthReceivedTime` | String | | +| `suitability` | Object | | | `tickSizeRules` | Array | | | `untradableDates` | Array | | @@ -569,6 +581,21 @@ Get orderbook information. | `minPrice` | Number | | | `tickSize` | Number | | +`getOrderbook().untradableDates[i]` + +| Property | Type | Note | +| :------- | :----- | ---- | +| `0` | String | | +| `1` | String | | +| `2` | String | | +| `3` | String | | +| `4` | String | | +| `5` | String | | +| `6` | String | | +| `7` | String | | +| `8` | String | | +| `9` | String | | + **Parameters** - `instrumentType` **[String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)** The type of the instrument. See diff --git a/lib/constants.js b/lib/constants.js index 27dd243..6af2a52 100644 --- a/lib/constants.js +++ b/lib/constants.js @@ -9,26 +9,26 @@ const constants = { * Paths */ constants.paths = {} -constants.paths.POSITIONS_PATH = '/_mobile/account/positions' -constants.paths.OVERVIEW_PATH = '/_mobile/account/overview' -constants.paths.ACCOUNT_OVERVIEW_PATH = '/_mobile/account/{0}/overview' -constants.paths.DEALS_AND_ORDERS_PATH = '/_mobile/account/dealsandorders' -constants.paths.WATCHLISTS_PATH = '/_mobile/usercontent/watchlist' -constants.paths.WATCHLISTS_ADD_PATH = '/_api/usercontent/watchlist/{0}/orderbooks/{1}' -constants.paths.STOCK_PATH = '/_mobile/market/stock/{0}' -constants.paths.FUND_PATH = '/_mobile/market/fund/{0}' -constants.paths.CERTIFICATE_PATH = '/_mobile/market/certificate/{0}' -constants.paths.INSTRUMENT_PATH = '/_mobile/market/{0}/{1}' -constants.paths.ORDERBOOK_PATH = '/_mobile/order/{0}' -constants.paths.ORDERBOOK_LIST_PATH = '/_mobile/market/orderbooklist/{0}' -constants.paths.CHARTDATA_PATH = '/_mobile/chart/orderbook/{0}' -constants.paths.ORDER_PLACE_DELETE_PATH = '/_api/order' -constants.paths.ORDER_EDIT_PATH = '/_api/order/{0}/{1}' -constants.paths.ORDER_GET_PATH = '/_mobile/order/{0}' -constants.paths.SEARCH_PATH = '/_mobile/market/search/{0}' -constants.paths.AUTHENTICATION_PATH = '/_api/authentication/sessions/username' -constants.paths.INSPIRATION_LIST_PATH = '/_mobile/marketing/inspirationlist/{0}' -constants.paths.TRANSACTIONS_PATH = '/_mobile/account/transactions/{0}' +constants.paths.POSITIONS_PATH = '/_mobile/account/positions' +constants.paths.OVERVIEW_PATH = '/_mobile/account/overview' +constants.paths.ACCOUNT_OVERVIEW_PATH = '/_mobile/account/{0}/overview' +constants.paths.DEALS_AND_ORDERS_PATH = '/_mobile/account/dealsandorders' +constants.paths.WATCHLISTS_PATH = '/_mobile/usercontent/watchlist' +constants.paths.WATCHLISTS_ADD_DELETE_PATH = '/_api/usercontent/watchlist/{0}/orderbooks/{1}' +constants.paths.STOCK_PATH = '/_mobile/market/stock/{0}' +constants.paths.FUND_PATH = '/_mobile/market/fund/{0}' +constants.paths.CERTIFICATE_PATH = '/_mobile/market/certificate/{0}' +constants.paths.INSTRUMENT_PATH = '/_mobile/market/{0}/{1}' +constants.paths.ORDERBOOK_PATH = '/_mobile/order/{0}' +constants.paths.ORDERBOOK_LIST_PATH = '/_mobile/market/orderbooklist/{0}' +constants.paths.CHARTDATA_PATH = '/_mobile/chart/orderbook/{0}' +constants.paths.ORDER_PLACE_DELETE_PATH = '/_api/order' +constants.paths.ORDER_EDIT_PATH = '/_api/order/{0}/{1}' +constants.paths.ORDER_GET_PATH = '/_mobile/order/{0}' +constants.paths.SEARCH_PATH = '/_mobile/market/search/{0}' +constants.paths.AUTHENTICATION_PATH = '/_api/authentication/sessions/username' +constants.paths.INSPIRATION_LIST_PATH = '/_mobile/marketing/inspirationlist/{0}' +constants.paths.TRANSACTIONS_PATH = '/_mobile/account/transactions/{0}' /** * Search diff --git a/lib/index.js b/lib/index.js index e34ef29..2979109 100644 --- a/lib/index.js +++ b/lib/index.js @@ -380,12 +380,25 @@ class Avanza extends EventEmitter { * @param {String} watchlistId The ID of the watchlist to add the instrument to. */ addToWatchlist(instrumentId, watchlistId) { - const path = constants.paths.WATCHLISTS_ADD_PATH + const path = constants.paths.WATCHLISTS_ADD_DELETE_PATH .replace('{0}', watchlistId) .replace('{1}', instrumentId) return this.call('PUT', path) } + /** + * Remove an instrument from the watchlist. + * + * @param {String} instrumentId The ID of the instrument to remove. + * @param {String} watchlistId The ID of the watchlist to remove the instrument from. + */ + removeFromWatchlist(instrumentId, watchlistId) { + const path = constants.paths.WATCHLISTS_ADD_DELETE_PATH + .replace('{0}', watchlistId) + .replace('{1}', instrumentId) + return this.call('DELETE', path) + } + /** * Get instrument information. * diff --git a/tests/index.test.js b/tests/index.test.js index 91380ef..0f2cc74 100644 --- a/tests/index.test.js +++ b/tests/index.test.js @@ -59,7 +59,7 @@ test('getTransactions() with options', async (t) => { test('addToWatchlist()', async (t) => { await t.context.avanza.addToWatchlist('12345', '54321') - const expectedPath = constants.paths.WATCHLISTS_ADD_PATH + const expectedPath = constants.paths.WATCHLISTS_ADD_DELETE_PATH .replace('{1}', '12345') .replace('{0}', '54321') @@ -68,6 +68,18 @@ test('addToWatchlist()', async (t) => { t.deepEqual(actual, expected) }) +test('removeFromWatchlist()', async (t) => { + await t.context.avanza.removeFromWatchlist('12345', '54321') + + const expectedPath = constants.paths.WATCHLISTS_ADD_DELETE_PATH + .replace('{1}', '12345') + .replace('{0}', '54321') + + const actual = t.context.call.args[0] + const expected = ['DELETE', expectedPath] + t.deepEqual(actual, expected) +}) + test('getInstrument()', async (t) => { await t.context.avanza.getInstrument('STOCK', '12345')