disable anything cost related other than direct content cost
This commit is contained in:
parent
33c5158818
commit
7b7a63b892
2 changed files with 46 additions and 62 deletions
|
@ -33,26 +33,53 @@ export function doFetchCostInfoForUri(uri) {
|
|||
});
|
||||
}
|
||||
|
||||
if (isGenerous && claim) {
|
||||
let cost;
|
||||
const fee = claim.value &&
|
||||
claim.value.stream &&
|
||||
claim.value.stream.metadata
|
||||
? claim.value.stream.metadata.fee
|
||||
: undefined;
|
||||
if (fee === undefined) {
|
||||
resolve({ cost: 0, includesData: true });
|
||||
} else if (fee.currency == "LBC") {
|
||||
resolve({ cost: fee.amount, includesData: true });
|
||||
} else {
|
||||
// begin();
|
||||
lbryio.getExchangeRates().then(({ lbc_usd }) => {
|
||||
resolve({ cost: fee.amount / lbc_usd, includesData: true });
|
||||
});
|
||||
}
|
||||
/**
|
||||
* "Generous" check below is disabled. We're no longer attempting to include or estimate data fees regardless of settings.
|
||||
*
|
||||
* This should be modified when lbry.stream_cost_estimate is reliable and performant.
|
||||
*/
|
||||
|
||||
/*
|
||||
lbry.stream_cost_estimate({ uri }).then(cost => {
|
||||
cacheAndResolve(cost);
|
||||
}, reject);
|
||||
*/
|
||||
|
||||
const fee = claim.value && claim.value.stream && claim.value.stream.metadata
|
||||
? claim.value.stream.metadata.fee
|
||||
: undefined;
|
||||
|
||||
if (fee === undefined) {
|
||||
resolve({ cost: 0, includesData: true });
|
||||
} else if (fee.currency == "LBC") {
|
||||
resolve({ cost: fee.amount, includesData: true });
|
||||
} else {
|
||||
begin();
|
||||
lbry.getCostInfo(uri).then(resolve);
|
||||
// begin();
|
||||
lbryio.getExchangeRates().then(({ lbc_usd }) => {
|
||||
resolve({ cost: fee.amount / lbc_usd, includesData: true });
|
||||
});
|
||||
}
|
||||
|
||||
// if (isGenerous && claim) {
|
||||
// let cost;
|
||||
// const fee = claim.value &&
|
||||
// claim.value.stream &&
|
||||
// claim.value.stream.metadata
|
||||
// ? claim.value.stream.metadata.fee
|
||||
// : undefined;
|
||||
// if (fee === undefined) {
|
||||
// resolve({ cost: 0, includesData: true });
|
||||
// } else if (fee.currency == "LBC") {
|
||||
// resolve({ cost: fee.amount, includesData: true });
|
||||
// } else {
|
||||
// // begin();
|
||||
// lbryio.getExchangeRates().then(({ lbc_usd }) => {
|
||||
// resolve({ cost: fee.amount / lbc_usd, includesData: true });
|
||||
// });
|
||||
// }
|
||||
// } else {
|
||||
// begin();
|
||||
// lbry.getCostInfo(uri).then(resolve);
|
||||
// }
|
||||
};
|
||||
}
|
||||
|
|
|
@ -176,49 +176,6 @@ lbry.connect = function() {
|
|||
return lbry._connectPromise;
|
||||
};
|
||||
|
||||
/**
|
||||
* Takes a LBRY URI; will first try and calculate a total cost using
|
||||
* Lighthouse. If Lighthouse can't be reached, it just retrives the
|
||||
* key fee.
|
||||
*
|
||||
* Returns an object with members:
|
||||
* - cost: Number; the calculated cost of the name
|
||||
* - includes_data: Boolean; indicates whether or not the data fee info
|
||||
* from Lighthouse is included.
|
||||
*/
|
||||
lbry.costPromiseCache = {};
|
||||
lbry.getCostInfo = function(uri) {
|
||||
if (lbry.costPromiseCache[uri] === undefined) {
|
||||
lbry.costPromiseCache[uri] = new Promise((resolve, reject) => {
|
||||
const COST_INFO_CACHE_KEY = "cost_info_cache";
|
||||
let costInfoCache = getSession(COST_INFO_CACHE_KEY, {});
|
||||
|
||||
function cacheAndResolve(cost) {
|
||||
const includesData = false;
|
||||
costInfoCache[uri] = { cost, includesData };
|
||||
setSession(COST_INFO_CACHE_KEY, costInfoCache);
|
||||
resolve({ cost, includesData });
|
||||
}
|
||||
|
||||
if (!uri) {
|
||||
return reject(new Error(`URI required.`));
|
||||
}
|
||||
|
||||
if (costInfoCache[uri] && costInfoCache[uri].cost) {
|
||||
return resolve(costInfoCache[uri]);
|
||||
}
|
||||
|
||||
const uriObj = lbryuri.parse(uri);
|
||||
const name = uriObj.path || uriObj.name;
|
||||
|
||||
lbry.stream_cost_estimate({ uri }).then(cost => {
|
||||
cacheAndResolve(cost);
|
||||
}, reject);
|
||||
});
|
||||
}
|
||||
return lbry.costPromiseCache[uri];
|
||||
};
|
||||
|
||||
/**
|
||||
* Publishes a file. The optional fileListedCallback is called when the file becomes available in
|
||||
* lbry.file_list() during the publish process.
|
||||
|
|
Loading…
Add table
Reference in a new issue