diff options
Diffstat (limited to '')
-rw-r--r-- | nodejs/lib/contracts.ts | 6 | ||||
-rw-r--r-- | nodejs/lib/ships.ts | 54 |
2 files changed, 30 insertions, 30 deletions
diff --git a/nodejs/lib/contracts.ts b/nodejs/lib/contracts.ts index 0adb5f6..54347cb 100644 --- a/nodejs/lib/contracts.ts +++ b/nodejs/lib/contracts.ts @@ -10,6 +10,7 @@ import * as dbShips from '../database/ships.ts'; import * as libShips from '../lib/ships.ts'; export async function accept(contract: Contract): Promise<Contract> { + contract = dbContracts.getContract(contract.id); if (contract.accepted) return contract; const response = await api.send<{agent: Agent, contract: Contract, type: ''}>({endpoint: `/my/contracts/${contract.id}/accept`, method: 'POST'}); if (response.error) { @@ -28,13 +29,15 @@ export async function contracts(): Promise<Array<Contract>> { } export async function deliver(contract: Contract, ship: Ship): Promise<Contract> { + contract = dbContracts.getContract(contract.id); + ship = dbShips.getShip(ship.symbol); if (contract.terms.deliver[0].unitsRequired >= contract.terms.deliver[0].unitsFulfilled) { return await fulfill(contract); } const tradeSymbol = contract.terms.deliver[0].tradeSymbol; let units = 0; ship.cargo.inventory.forEach(i => {if (i.symbol === tradeSymbol) units = i.units; }); - ship = await libShips.dock(ship); // we need to be docked to deliver + await libShips.dock(ship); // we need to be docked to deliver const response = await api.send<{contract: Contract, cargo: Cargo}>({ endpoint: `/my/contracts/${contract.id}/deliver`, method: 'POST', payload: { shipSymbol: ship.symbol, tradeSymbol: tradeSymbol, @@ -58,6 +61,7 @@ export async function deliver(contract: Contract, ship: Ship): Promise<Contract> } export async function fulfill(contract: Contract): Promise<Contract> { + contract = dbContracts.getContract(contract.id); if (contract.fulfilled) return contract; const response = await api.send<{agent: Agent, contract: Contract}>({ endpoint: `/my/contracts/${contract.id}/fulfill`, method: 'POST'}); if (response.error) { diff --git a/nodejs/lib/ships.ts b/nodejs/lib/ships.ts index 955824e..79b20a6 100644 --- a/nodejs/lib/ships.ts +++ b/nodejs/lib/ships.ts @@ -8,8 +8,9 @@ import * as dbShips from '../database/ships.ts'; //import * as dbSurveys from '../database/surveys.ts'; import * as systems from '../lib/systems.ts'; -export async function dock(ship: Ship): Promise<Ship> { - if (ship.nav.status === 'DOCKED') return ship; +export async function dock(ship: Ship): Promise<void> { + ship = dbShips.getShip(ship.symbol); + if (ship.nav.status === 'DOCKED') return; const response = await api.send<{nav: Nav}>({endpoint: `/my/ships/${ship.symbol}/dock`, method: 'POST'}); if (response.error) { switch(response.error.code) { @@ -23,16 +24,16 @@ export async function dock(ship: Ship): Promise<Ship> { } } dbShips.setShipNav(ship.symbol, response.data.nav); - ship.nav = response.data.nav; - return ship; } -export async function extract(ship: Ship): Promise<Ship> { +export async function extract(ship: Ship): Promise<Cargo> { + ship = dbShips.getShip(ship.symbol); + if (ship.cargo.units >= ship.cargo.capacity * 0.9) return ship.cargo; // TODO move to a suitable asteroid? // const asteroidFields = await systems.type({symbol: ship.nav.systemSymbol, type: 'ENGINEERED_ASTEROID'}); // TODO if there are multiple fields, find the closest one? //await navigate({symbol: ctx.symbol, waypoint: asteroidFields[0].symbol}); - ship = await orbit(ship); + await orbit(ship); // TODO handle surveying? const response = await api.send<{cooldown: Cooldown, cargo: Cargo}>({endpoint: `/my/ships/${ship.symbol}/extract`, method: 'POST'}); // TODO extraction and events api response fields cf https://spacetraders.stoplight.io/docs/spacetraders/b3931d097608d-extract-resources if (response.error) { @@ -42,17 +43,16 @@ export async function extract(ship: Ship): Promise<Ship> { await api.sleep(errorData.cooldown.remainingSeconds * 1000); return await extract(ship); case 4228: // ship is full - return ship; + return ship.cargo; default: // yet unhandled error api.debugLog(response); throw response; } } else { dbShips.setShipCargo(ship.symbol, response.data.cargo); - ship.cargo = response.data.cargo; await api.sleep(response.data.cooldown.remainingSeconds*1000); } - return ship; + return response.data.cargo } //function hasMount(shipSymbol, mountSymbol) { @@ -67,9 +67,10 @@ export async function extract(ship: Ship): Promise<Ship> { // return response; //} -export async function navigate(ship: Ship, waypoint: string): Promise<Ship> { - if (ship.nav.waypointSymbol === waypoint) return ship; - ship = await orbit(ship); +export async function navigate(ship: Ship, waypoint: string): Promise<void> { + ship = dbShips.getShip(ship.symbol); + if (ship.nav.waypointSymbol === waypoint) return; + await orbit(ship); // TODO if we do not have enough fuel, make a stop to refuel along the way or drift to the destination const response = await api.send<{fuel: Fuel, nav: Nav}>({endpoint: `/my/ships/${ship.symbol}/navigate`, method: 'POST', payload: { waypointSymbol: waypoint }}); // TODO events field if (response.error) { @@ -85,15 +86,12 @@ export async function navigate(ship: Ship, waypoint: string): Promise<Ship> { } dbShips.setShipFuel(ship.symbol, response.data.fuel); dbShips.setShipNav(ship.symbol, response.data.nav); - ship.fuel = response.data.fuel; - ship.nav = response.data.nav const delay = new Date(response.data.nav.route.arrival).getTime() - new Date().getTime() ; await api.sleep(delay); response.data.nav.status = 'IN_ORBIT'; // we arrive in orbit dbShips.setShipNav(ship.symbol, response.data.nav); - ship.nav = response.data.nav // TODO only refuel at the start of a journey, if we do not have enough OR if the destination does not sell fuel? - return await refuel(ship); + await refuel(ship); } //export async function negotiate(ctx) { @@ -101,8 +99,9 @@ export async function navigate(ship: Ship, waypoint: string): Promise<Ship> { // return await api.send({endpoint: `/my/ships/${ctx.ship}/negotiate/contract`, method: 'POST'}); //} -export async function orbit(ship: Ship): Promise<Ship> { - if (ship.nav.status === 'IN_ORBIT') return ship; +export async function orbit(ship: Ship): Promise<void> { + ship = dbShips.getShip(ship.symbol); + if (ship.nav.status === 'IN_ORBIT') return; const response = await api.send<{nav: Nav}>({endpoint: `/my/ships/${ship.symbol}/orbit`, method: 'POST'}); if (response.error) { switch(response.error.code) { @@ -115,8 +114,6 @@ export async function orbit(ship: Ship): Promise<Ship> { } } dbShips.setShipNav(ship.symbol, response.data.nav); - ship.nav = response.data.nav; - return ship; } //export async function purchase(ctx) { @@ -131,10 +128,11 @@ export async function orbit(ship: Ship): Promise<Ship> { // return response.data; //} -export async function refuel(ship: Ship): Promise<Ship> { - if (ship.fuel.current >= ship.fuel.capacity * 0.9) return ship; +export async function refuel(ship: Ship): Promise<void> { + ship = dbShips.getShip(ship.symbol); + if (ship.fuel.current >= ship.fuel.capacity * 0.9) return; // TODO check if our current waypoint has a marketplace (and sells fuel)? - ship = await dock(ship); + await dock(ship); const response = await api.send<{agent: Agent, fuel: Fuel}>({endpoint: `/my/ships/${ship.symbol}/refuel`, method: 'POST'}); // TODO transaction field if (response.error) { api.debugLog(response); @@ -142,13 +140,12 @@ export async function refuel(ship: Ship): Promise<Ship> { } dbShips.setShipFuel(ship.symbol, response.data.fuel); dbAgents.setAgent(response.data.agent); - ship.fuel = response.data.fuel; - return ship; } -export async function sell(ship: Ship, tradeSymbol: string): Promise<Ship> { +export async function sell(ship: Ship, tradeSymbol: string): Promise<Cargo> { + ship = dbShips.getShip(ship.symbol); // TODO check if our current waypoint has a marketplace and buys tradeSymbol? - ship = await dock(ship); + await dock(ship); let units = 0; ship.cargo.inventory.forEach(i => {if (i.symbol === tradeSymbol) units = i.units; }); const response = await api.send<{agent: Agent, cargo: Cargo}>({endpoint: `/my/ships/${ship.symbol}/sell`, method: 'POST', payload: { symbol: tradeSymbol, units: units }}); // TODO transaction field @@ -158,8 +155,7 @@ export async function sell(ship: Ship, tradeSymbol: string): Promise<Ship> { } dbShips.setShipCargo(ship.symbol, response.data.cargo); dbAgents.setAgent(response.data.agent); - ship.cargo = response.data.cargo; - return ship; + return response.data.cargo; } export async function ships(): Promise<Array<Ship>> { |