[javascript] implemented contract fulfillment
This commit is contained in:
parent
4dd8a2e90f
commit
378b5a5ffb
3 changed files with 36 additions and 8 deletions
|
@ -34,7 +34,7 @@ async function runProcurement(contract, ships) {
|
||||||
const asteroidFields = await systems.type({symbol: ships[0].nav.systemSymbol, type: 'ASTEROID_FIELD'});
|
const asteroidFields = await systems.type({symbol: ships[0].nav.systemSymbol, type: 'ASTEROID_FIELD'});
|
||||||
const asteroidField = asteroidFields[0].symbol;
|
const asteroidField = asteroidFields[0].symbol;
|
||||||
ships.forEach(async function(ship) {
|
ships.forEach(async function(ship) {
|
||||||
while (!contract.fulfilled) {
|
while (!dbContracts.getContract(contract.id).fulfilled) {
|
||||||
ship = dbShips.getShip(ship.symbol);
|
ship = dbShips.getShip(ship.symbol);
|
||||||
let goodCargo = ship.cargo.inventory.filter(i => i.symbol === wantedCargo)[0];
|
let goodCargo = ship.cargo.inventory.filter(i => i.symbol === wantedCargo)[0];
|
||||||
// If we are in transit, we wait until we arrive
|
// If we are in transit, we wait until we arrive
|
||||||
|
@ -49,8 +49,9 @@ async function runProcurement(contract, ships) {
|
||||||
case deliveryPoint:
|
case deliveryPoint:
|
||||||
if (goodCargo !== undefined) { // we could be here if a client restart happens right after selling before we navigate away
|
if (goodCargo !== undefined) { // we could be here if a client restart happens right after selling before we navigate away
|
||||||
console.log(`delivering ${goodCargo.units} of ${wantedCargo}`);
|
console.log(`delivering ${goodCargo.units} of ${wantedCargo}`);
|
||||||
await contracts.deliver({contract: contract.id, symbol: ship.symbol, good: wantedCargo, units: goodCargo.units });
|
if (await contracts.deliver({id: contract.id, symbol: ship.symbol, good: wantedCargo, units: goodCargo.units })) {
|
||||||
// TODO check if contract is fulfilled!
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
await libShips.navigate({symbol: ship.symbol, waypoint: asteroidField});
|
await libShips.navigate({symbol: ship.symbol, waypoint: asteroidField});
|
||||||
break;
|
break;
|
||||||
|
@ -58,5 +59,6 @@ async function runProcurement(contract, ships) {
|
||||||
await libShips.navigate({symbol: ship.symbol, waypoint: asteroidField});
|
await libShips.navigate({symbol: ship.symbol, waypoint: asteroidField});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// TODO repurpose the ship
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,21 +19,48 @@ export async function contracts() {
|
||||||
return contracts;
|
return contracts;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// returns true if the contract has been fulfilled
|
||||||
export async function deliver(ctx) {
|
export async function deliver(ctx) {
|
||||||
|
const contract = dbContracts.getContract(ctx.id);
|
||||||
|
if (contract.terms.deliver[0].unitsRequired === contract.terms.deliver[0].unitsFulfilled) {
|
||||||
|
await fulfill(ctx);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
await libShips.dock(ctx);
|
await libShips.dock(ctx);
|
||||||
const response = await api.send({ endpoint: `/my/contracts/${ctx.contract}/deliver`, method: 'POST', payload: {
|
const response = await api.send({ endpoint: `/my/contracts/${ctx.id}/deliver`, method: 'POST', payload: {
|
||||||
shipSymbol: ctx.symbol,
|
shipSymbol: ctx.symbol,
|
||||||
tradeSymbol: ctx.good,
|
tradeSymbol: ctx.good,
|
||||||
units: ctx.units,
|
units: ctx.units,
|
||||||
}});
|
}});
|
||||||
if (response.error !== undefined) {
|
if (response.error !== undefined) {
|
||||||
|
switch(response.error.code) {
|
||||||
|
case 4509: // contract delivery terms have been met
|
||||||
|
await fulfill(ctx);
|
||||||
|
return true;
|
||||||
|
default: // yet unhandled error
|
||||||
|
api.debugLog(response);
|
||||||
throw response;
|
throw response;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
dbContracts.setContract(response.data.contract);
|
||||||
dbShips.setShipCargo(ctx.symbol, response.data.cargo);
|
dbShips.setShipCargo(ctx.symbol, response.data.cargo);
|
||||||
// TODO update contract delivered units
|
|
||||||
// TODO track credits
|
// TODO track credits
|
||||||
|
if(response.data.contract.terms.deliver[0].unitsRequired === response.data.contract.terms.deliver[0].unitsFulfilled) {
|
||||||
|
await fulfill(ctx);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function fulfill(ctx) {
|
export async function fulfill(ctx) {
|
||||||
return await api.send({ endpoint: `/my/contracts/${ctx.contract}/fulfill`, method: 'POST'});
|
const contract = dbContracts.getContract(ctx.id);
|
||||||
|
if (contract.fulfilled) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const response = await api.send({ endpoint: `/my/contracts/${ctx.id}/fulfill`, method: 'POST'});
|
||||||
|
if (response.error !== undefined) {
|
||||||
|
api.debugLog(response);
|
||||||
|
throw response;
|
||||||
|
}
|
||||||
|
dbContracts.setContract(response.data.contract);
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ import * as autoExploring from './automation/exploration.js';
|
||||||
import * as autoInit from './automation/init.js';
|
import * as autoInit from './automation/init.js';
|
||||||
import * as api from './lib/api.js';
|
import * as api from './lib/api.js';
|
||||||
import * as contracts from './lib/contracts.js';
|
import * as contracts from './lib/contracts.js';
|
||||||
import * as ships from './lib/ships.js';
|
|
||||||
|
|
||||||
await autoInit.init();
|
await autoInit.init();
|
||||||
autoContracting.init();
|
autoContracting.init();
|
||||||
|
|
Loading…
Add table
Reference in a new issue