|
@ -1,293 +1,7 @@ |
|
|
const { |
|
|
const { PrismaClient } = require('@prisma/client'); |
|
|
AccountType, |
|
|
|
|
|
DataSource, |
|
|
|
|
|
PrismaClient, |
|
|
|
|
|
Role, |
|
|
|
|
|
Type |
|
|
|
|
|
} = require('@prisma/client'); |
|
|
|
|
|
const prisma = new PrismaClient(); |
|
|
const prisma = new PrismaClient(); |
|
|
|
|
|
|
|
|
async function main() { |
|
|
async function main() { |
|
|
const platformBitcoinSuisse = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '70b6e475-a2b9-4527-99db-943e4f38ce45', |
|
|
|
|
|
name: 'Bitcoin Suisse', |
|
|
|
|
|
url: 'https://www.bitcoinsuisse.com' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '70b6e475-a2b9-4527-99db-943e4f38ce45' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformBitpanda = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: 'debf9110-498f-4811-b972-7ebbd317e730', |
|
|
|
|
|
name: 'Bitpanda', |
|
|
|
|
|
url: 'https://www.bitpanda.com' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: 'debf9110-498f-4811-b972-7ebbd317e730' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformCoinbase = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '8dc24b88-bb92-4152-af25-fe6a31643e26', |
|
|
|
|
|
name: 'Coinbase', |
|
|
|
|
|
url: 'https://www.coinbase.com' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '8dc24b88-bb92-4152-af25-fe6a31643e26' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformDegiro = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '94c1a2f4-a666-47be-84cd-4c8952e74c81', |
|
|
|
|
|
name: 'DEGIRO', |
|
|
|
|
|
url: 'https://www.degiro.eu' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '94c1a2f4-a666-47be-84cd-4c8952e74c81' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformInteractiveBrokers = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '9da3a8a7-4795-43e3-a6db-ccb914189737', |
|
|
|
|
|
name: 'Interactive Brokers', |
|
|
|
|
|
url: 'https://www.interactivebrokers.com' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '9da3a8a7-4795-43e3-a6db-ccb914189737' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformPostFinance = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '5377d9df-0d25-42c2-9d9b-e4c63166281e', |
|
|
|
|
|
name: 'PostFinance', |
|
|
|
|
|
url: 'https://www.postfinance.ch' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '5377d9df-0d25-42c2-9d9b-e4c63166281e' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const platformSwissquote = await prisma.platform.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
id: '1377d9df-0d25-42c2-9d9b-e4c63156291f', |
|
|
|
|
|
name: 'Swissquote', |
|
|
|
|
|
url: 'https://swissquote.com' |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '1377d9df-0d25-42c2-9d9b-e4c63156291f' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
const userDemo = await prisma.user.upsert({ |
|
|
|
|
|
create: { |
|
|
|
|
|
accessToken: |
|
|
|
|
|
'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IjliMTEyYjRkLTNiN2QtNGJhZC05YmRkLTNiMGY3YjRkYWMyZiIsImlhdCI6MTYxODUxMjAxNCwiZXhwIjoxNjIxMTA0MDE0fQ.l3WUxpI0hxuQtdPrD0kd7sem6S2kx_7CrdNvkmlKuWw', |
|
|
|
|
|
Account: { |
|
|
|
|
|
create: [ |
|
|
|
|
|
{ |
|
|
|
|
|
accountType: AccountType.SECURITIES, |
|
|
|
|
|
balance: 0, |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
id: 'd804de69-0429-42dc-b6ca-b308fd7dd926', |
|
|
|
|
|
name: 'Coinbase Account', |
|
|
|
|
|
platformId: platformCoinbase.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountType: AccountType.SECURITIES, |
|
|
|
|
|
balance: 0, |
|
|
|
|
|
currency: 'EUR', |
|
|
|
|
|
id: '65cfb79d-b6c7-4591-9d46-73426bc62094', |
|
|
|
|
|
name: 'DEGIRO Account', |
|
|
|
|
|
platformId: platformDegiro.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountType: AccountType.SECURITIES, |
|
|
|
|
|
balance: 0, |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
id: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
isDefault: true, |
|
|
|
|
|
name: 'Interactive Brokers Account', |
|
|
|
|
|
platformId: platformInteractiveBrokers.id |
|
|
|
|
|
} |
|
|
|
|
|
] |
|
|
|
|
|
}, |
|
|
|
|
|
id: '9b112b4d-3b7d-4bad-9bdd-3b0f7b4dac2f', |
|
|
|
|
|
role: Role.DEMO |
|
|
|
|
|
}, |
|
|
|
|
|
update: {}, |
|
|
|
|
|
where: { id: '9b112b4d-3b7d-4bad-9bdd-3b0f7b4dac2f' } |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
await prisma.symbolProfile.createMany({ |
|
|
|
|
|
data: [ |
|
|
|
|
|
{ |
|
|
|
|
|
assetClass: 'EQUITY', |
|
|
|
|
|
assetSubClass: 'STOCK', |
|
|
|
|
|
countries: [{ code: 'US', weight: 1 }], |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
dataSource: DataSource.YAHOO, |
|
|
|
|
|
id: '2bd26362-136e-411c-b578-334084b4cdcc', |
|
|
|
|
|
name: 'Amazon.com Inc.', |
|
|
|
|
|
sectors: [{ name: 'Consumer Cyclical', weight: 1 }], |
|
|
|
|
|
symbol: 'AMZN' |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
assetClass: 'CASH', |
|
|
|
|
|
assetSubClass: 'CRYPTOCURRENCY', |
|
|
|
|
|
countries: undefined, |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
dataSource: DataSource.YAHOO, |
|
|
|
|
|
id: 'fdc42ea6-1321-44f5-9fb0-d7f1f2cf9b1e', |
|
|
|
|
|
name: 'Bitcoin USD', |
|
|
|
|
|
sectors: undefined, |
|
|
|
|
|
symbol: 'BTCUSD' |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
assetClass: 'EQUITY', |
|
|
|
|
|
assetSubClass: 'STOCK', |
|
|
|
|
|
countries: [{ code: 'US', weight: 1 }], |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
dataSource: DataSource.YAHOO, |
|
|
|
|
|
id: 'd1ee9681-fb21-4f99-a3b7-afd4fc04df2e', |
|
|
|
|
|
name: 'Tesla Inc.', |
|
|
|
|
|
sectors: [{ name: 'Consumer Cyclical', weight: 1 }], |
|
|
|
|
|
symbol: 'TSLA' |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
assetClass: 'EQUITY', |
|
|
|
|
|
assetSubClass: 'ETF', |
|
|
|
|
|
countries: [ |
|
|
|
|
|
{ code: 'US', weight: 0.9886789999999981 }, |
|
|
|
|
|
{ code: 'NL', weight: 0.000203 }, |
|
|
|
|
|
{ code: 'CA', weight: 0.000362 } |
|
|
|
|
|
], |
|
|
|
|
|
currency: 'USD', |
|
|
|
|
|
dataSource: DataSource.YAHOO, |
|
|
|
|
|
id: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', |
|
|
|
|
|
name: 'Vanguard Total Stock Market Index Fund ETF', |
|
|
|
|
|
sectors: [ |
|
|
|
|
|
{ name: 'Technology', weight: 0.31393799999999955 }, |
|
|
|
|
|
{ name: 'Consumer Cyclical', weight: 0.149224 }, |
|
|
|
|
|
{ name: 'Financials', weight: 0.11716100000000002 }, |
|
|
|
|
|
{ name: 'Healthcare', weight: 0.13285199999999994 }, |
|
|
|
|
|
{ name: 'Consumer Staples', weight: 0.053919000000000016 }, |
|
|
|
|
|
{ name: 'Energy', weight: 0.025529999999999997 }, |
|
|
|
|
|
{ name: 'Telecommunications', weight: 0.012579 }, |
|
|
|
|
|
{ name: 'Industrials', weight: 0.09526399999999995 }, |
|
|
|
|
|
{ name: 'Utilities', weight: 0.024791999999999988 }, |
|
|
|
|
|
{ name: 'Materials', weight: 0.027664 }, |
|
|
|
|
|
{ name: 'Real Estate', weight: 0.03239999999999998 }, |
|
|
|
|
|
{ name: 'Communication', weight: 0.0036139999999999996 }, |
|
|
|
|
|
{ name: 'Other', weight: 0.000218 } |
|
|
|
|
|
], |
|
|
|
|
|
symbol: 'VTI' |
|
|
|
|
|
} |
|
|
|
|
|
], |
|
|
|
|
|
skipDuplicates: true |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
await prisma.order.createMany({ |
|
|
|
|
|
data: [ |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '65cfb79d-b6c7-4591-9d46-73426bc62094', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2017, 0, 3, 0, 0, 0)), |
|
|
|
|
|
fee: 30, |
|
|
|
|
|
id: 'cf7c0418-8535-4089-ae3d-5dbfa0aec2e1', |
|
|
|
|
|
quantity: 50, |
|
|
|
|
|
symbolProfileId: 'd1ee9681-fb21-4f99-a3b7-afd4fc04df2e', // TSLA
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 42.97, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: 'd804de69-0429-42dc-b6ca-b308fd7dd926', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2017, 7, 16, 0, 0, 0)), |
|
|
|
|
|
fee: 29.9, |
|
|
|
|
|
id: 'a1c5d73a-8631-44e5-ac44-356827a5212c', |
|
|
|
|
|
quantity: 0.5614682, |
|
|
|
|
|
symbolProfileId: 'fdc42ea6-1321-44f5-9fb0-d7f1f2cf9b1e', // BTCUSD
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 3562.089535970158, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2018, 9, 1, 0, 0, 0)), |
|
|
|
|
|
fee: 80.79, |
|
|
|
|
|
id: '71c08e2a-4a86-44ae-a890-c337de5d5f9b', |
|
|
|
|
|
quantity: 5, |
|
|
|
|
|
symbolProfileId: '2bd26362-136e-411c-b578-334084b4cdcc', // AMZN
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 2021.99, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2019, 2, 1, 0, 0, 0)), |
|
|
|
|
|
fee: 19.9, |
|
|
|
|
|
id: '385f2c2c-d53e-4937-b0e5-e92ef6020d4e', |
|
|
|
|
|
quantity: 10, |
|
|
|
|
|
symbolProfileId: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', // VTI
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 144.38, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2019, 8, 3, 0, 0, 0)), |
|
|
|
|
|
fee: 19.9, |
|
|
|
|
|
id: '185f2c2c-d53e-4937-b0e5-a93ef6020d4e', |
|
|
|
|
|
quantity: 10, |
|
|
|
|
|
symbolProfileId: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', // VTI
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 147.99, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2020, 2, 2, 0, 0, 0)), |
|
|
|
|
|
fee: 19.9, |
|
|
|
|
|
id: '347b0430-a84f-4031-a0f9-390399066ad6', |
|
|
|
|
|
quantity: 10, |
|
|
|
|
|
symbolProfileId: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', // VTI
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 151.41, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2020, 8, 1, 0, 0, 0)), |
|
|
|
|
|
fee: 19.9, |
|
|
|
|
|
id: '67ec3f47-3189-4b63-ba05-60d3a06b302f', |
|
|
|
|
|
quantity: 10, |
|
|
|
|
|
symbolProfileId: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', // VTI
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 177.69, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
accountId: '480269ce-e12a-4fd1-ac88-c4b0ff3f899c', |
|
|
|
|
|
accountUserId: userDemo.id, |
|
|
|
|
|
date: new Date(Date.UTC(2020, 2, 1, 0, 0, 0)), |
|
|
|
|
|
fee: 19.9, |
|
|
|
|
|
id: 'd01c6fbc-fa8d-47e6-8e80-66f882d2bfd2', |
|
|
|
|
|
quantity: 10, |
|
|
|
|
|
symbolProfileId: '7d9c8540-061e-4e7e-b019-0d0f4a84e796', // VTI
|
|
|
|
|
|
type: Type.BUY, |
|
|
|
|
|
unitPrice: 203.15, |
|
|
|
|
|
userId: userDemo.id |
|
|
|
|
|
} |
|
|
|
|
|
], |
|
|
|
|
|
skipDuplicates: true |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
await prisma.tag.createMany({ |
|
|
await prisma.tag.createMany({ |
|
|
data: [ |
|
|
data: [ |
|
|
{ |
|
|
{ |
|
@ -297,17 +11,6 @@ async function main() { |
|
|
], |
|
|
], |
|
|
skipDuplicates: true |
|
|
skipDuplicates: true |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
console.log({ |
|
|
|
|
|
platformBitcoinSuisse, |
|
|
|
|
|
platformBitpanda, |
|
|
|
|
|
platformCoinbase, |
|
|
|
|
|
platformDegiro, |
|
|
|
|
|
platformInteractiveBrokers, |
|
|
|
|
|
platformPostFinance, |
|
|
|
|
|
platformSwissquote, |
|
|
|
|
|
userDemo |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
main() |
|
|
main() |
|
|