- Imported getChartData for barchart data from https://github.com/kfreskgard/avanza/commit/526b33c693c92ff1b66e531dc98657f7d323ca77
- Imported placeWebOrder from https://github.com/ausrasul/avanza/commit/aaa5fe0ab75860e3a809e41d805992c3f4ba726e to get order placement that works and can do fill or kill.
To build: npm run start
A Node.js wrapper for the unofficial Avanza API. Please note that this is only a proof of concept, hence not meant to be used by anyone.
It might also be valuable to note that I am not affiliated with Avanza Bank AB in any way. The underlying API can be taken down or changed without warning at any point in time.
Talos is hiring senior engineers! Send an email to filip+hiring
at talos.com
.
Install via npm
$ npm install avanza
Refer to API.md.
NOTE: Since May 2018 two-factor authentication is used to log in.
Here are the steps to get your TOTP Secret:
- Go to Mina Sidor > Profil > Sajtinställningar > Tvåfaktorsinloggning and click "Återaktivera". (Only do this step if you have already set up two-factor auth.)
- Click "Aktivera" on the next screen.
- Select "Annan app för tvåfaktorsinloggning".
- Click "Kan du inte scanna QR-koden?" to reveal your TOTP Secret.
- Finally, run
node -e "console.log(require('avanza/dist/totp')('PASTE_YOUR_TOTP_SECRET_HERE'))"
to generate an initial code. - Done! From now on all you have to do is supply your secret in the
authenticate()
function as in the example below.
Authenticate and fetch currently held positions:
import Avanza from 'avanza'
const avanza = new Avanza()
avanza.authenticate({
username: 'MY_USERNAME',
password: 'MY_PASSWORD',
totpSecret: 'MY_TOTP_SECRET'
}).then(async () => {
const positions = await avanza.getPositions()
console.log(positions)
})
Authenticate and subscribe to real-time data:
import Avanza from 'avanza'
const avanza = new Avanza()
avanza.authenticate({
username: 'USERNAME',
password: 'PASSWORD',
totpSecret: 'MY_TOTP_SECRET'
}).then(() => {
avanza.subscribe(Avanza.QUOTES, '5479', (quote) => {
console.log('Received quote:', quote)
})
})
Refer to API.md.
Tests will not run without an .env
file. Use the .env-example
as reference.
$ npm test
MIT license. See the LICENSE file for details.
The author of this software is not responsible for any indirect damages (foreseeable or unforeseeable), such as, if necessary, loss or alteration of or fraudulent access to data, accidental transmission of viruses or of any other harmful element, loss of profits or opportunities, the cost of replacement goods and services or the attitude and behavior of a third party.