|
|
|
import { Injectable, OnDestroy } from '@angular/core';
|
|
|
|
import { HttpClient } from '@angular/common/http';
|
|
|
|
import { Router } from '@angular/router';
|
|
|
|
import { Store } from '@ngrx/store';
|
|
|
|
import { Actions, Effect, ofType } from '@ngrx/effects';
|
|
|
|
import { of, Subject } from 'rxjs';
|
|
|
|
import { map, mergeMap, catchError, take, withLatestFrom } from 'rxjs/operators';
|
|
|
|
|
|
|
|
import { MatDialog } from '@angular/material';
|
|
|
|
|
|
|
|
import { environment, API_URL } from '../../../environments/environment';
|
|
|
|
import { LoggerService } from '../../shared/services/logger.service';
|
|
|
|
import { GetInfo, GetInfoChain, Fees, Balance, NetworkInfo, Payment, GraphNode, Transaction, SwitchReq, ListInvoices } from '../../shared/models/lndModels';
|
|
|
|
|
|
|
|
import * as RTLActions from '../../store/rtl.actions';
|
|
|
|
import * as fromRTLReducer from '../../store/rtl.reducers';
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class LNDEffects implements OnDestroy {
|
|
|
|
dialogRef: any;
|
|
|
|
CHILD_API_URL = API_URL + '/lnd';
|
|
|
|
private unSubs: Array<Subject<void>> = [new Subject(), new Subject()];
|
|
|
|
|
|
|
|
constructor(
|
|
|
|
private actions$: Actions,
|
|
|
|
private httpClient: HttpClient,
|
|
|
|
private store: Store<fromRTLReducer.RTLState>,
|
|
|
|
private logger: LoggerService,
|
|
|
|
public dialog: MatDialog,
|
|
|
|
private router: Router) { }
|
|
|
|
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
infoFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_INFO),
|
|
|
|
withLatestFrom(this.store.select('root')),
|
|
|
|
mergeMap(([action, store]) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchInfo'));
|
|
|
|
return this.httpClient.get<GetInfo>(this.CHILD_API_URL + environment.GETINFO_API)
|
|
|
|
.pipe(
|
|
|
|
map((info) => {
|
|
|
|
this.logger.info(info);
|
|
|
|
if (undefined === info.identity_pubkey) {
|
|
|
|
sessionStorage.removeItem('lndUnlocked');
|
|
|
|
this.logger.info('Redirecting to Unlock');
|
|
|
|
this.router.navigate(['/lnd/unlocklnd']);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_INFO,
|
|
|
|
payload: {}
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
sessionStorage.setItem('lndUnlocked', 'true');
|
|
|
|
if (undefined !== info.chains) {
|
|
|
|
if (typeof info.chains[0] === 'string') {
|
|
|
|
info.smaller_currency_unit = (info.chains[0].toString().toLowerCase().indexOf('bitcoin') < 0) ? 'Litoshis' : 'Sats';
|
|
|
|
info.currency_unit = (info.chains[0].toString().toLowerCase().indexOf('bitcoin') < 0) ? 'LTC' : 'BTC';
|
|
|
|
} else if (typeof info.chains[0] === 'object' && info.chains[0].hasOwnProperty('chain')) {
|
|
|
|
const getInfoChain = <GetInfoChain>info.chains[0];
|
|
|
|
info.smaller_currency_unit = (getInfoChain.chain.toLowerCase().indexOf('bitcoin') < 0) ? 'Litoshis' : 'Sats';
|
|
|
|
info.currency_unit = (getInfoChain.chain.toLowerCase().indexOf('bitcoin') < 0) ? 'LTC' : 'BTC';
|
|
|
|
}
|
|
|
|
info.version = (undefined === info.version) ? '' : info.version.split(' ')[0];
|
|
|
|
} else {
|
|
|
|
info.smaller_currency_unit = 'Sats';
|
|
|
|
info.currency_unit = 'BTC';
|
|
|
|
info.version = (undefined === info.version) ? '' : info.version.split(' ')[0];
|
|
|
|
}
|
|
|
|
const node_data = {
|
|
|
|
identity_pubkey: info.identity_pubkey,
|
|
|
|
alias: info.alias,
|
|
|
|
testnet: info.testnet,
|
|
|
|
chains: info.chains,
|
|
|
|
version: info.version,
|
|
|
|
currency_unit: info.currency_unit,
|
|
|
|
smaller_currency_unit: info.smaller_currency_unit,
|
|
|
|
numberOfPendingChannels: info.num_pending_channels
|
|
|
|
};
|
|
|
|
this.store.dispatch(new RTLActions.SetNodeData(node_data));
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_INFO,
|
|
|
|
payload: (undefined !== info) ? info : {}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
catchError((err) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
if (err.status === 401) {
|
|
|
|
this.logger.info('Redirecting to Signin');
|
|
|
|
return of({ type: RTLActions.SIGNOUT });
|
|
|
|
} else {
|
|
|
|
this.logger.info('Redirecting to Unlock');
|
|
|
|
this.router.navigate(['/lnd/unlocklnd']);
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
peersFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_PEERS),
|
|
|
|
mergeMap((action: RTLActions.FetchPeers) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchPeers'));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.PEERS_API)
|
|
|
|
.pipe(
|
|
|
|
map((peers: any) => {
|
|
|
|
this.logger.info(peers);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_PEERS,
|
|
|
|
payload: (undefined !== peers) ? peers : []
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchPeers', code: err.status, message: err.error.error }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
saveNewPeer = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SAVE_NEW_PEER),
|
|
|
|
mergeMap((action: RTLActions.SaveNewPeer) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.PEERS_API, { pubkey: action.payload.pubkey, host: action.payload.host, perm: action.payload.perm })
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: 'Peer Added Successfully!' } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_PEERS,
|
|
|
|
payload: (undefined !== postRes && postRes.length > 0) ? postRes : []
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Add Peer Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
detachPeer = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.DETACH_PEER),
|
|
|
|
mergeMap((action: RTLActions.DetachPeer) => {
|
|
|
|
return this.httpClient.delete(this.CHILD_API_URL + environment.PEERS_API + '/' + action.payload.pubkey)
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: 'Peer Detached Successfully!' } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.REMOVE_PEER,
|
|
|
|
payload: { pubkey: action.payload.pubkey }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Unable to Detach Peer. Try again later.',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
saveNewInvoice = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SAVE_NEW_INVOICE),
|
|
|
|
mergeMap((action: RTLActions.SaveNewInvoice) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.INVOICES_API, {
|
|
|
|
memo: action.payload.memo, amount: action.payload.invoiceValue, private: action.payload.private, expiry: action.payload.expiry
|
|
|
|
})
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
postRes.memo = action.payload.memo;
|
|
|
|
postRes.value = action.payload.invoiceValue;
|
|
|
|
postRes.expiry = action.payload.expiry;
|
|
|
|
postRes.cltv_expiry = '144';
|
|
|
|
postRes.creation_date = Math.round(new Date().getTime() / 1000).toString();
|
|
|
|
postRes.creation_date_str = new Date(+postRes.creation_date * 1000).toUTCString();
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
const msg = { payment_request: postRes.payment_request };
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({
|
|
|
|
width: '70%',
|
|
|
|
data: { type: 'SUCCESS', titleMessage: 'Invoice Added Successfully!', message: JSON.stringify(msg) }
|
|
|
|
}));
|
|
|
|
return {
|
|
|
|
type: RTLActions.FETCH_INVOICES,
|
|
|
|
payload: { num_max_invoices: action.payload.pageSize, reversed: true }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Add Invoice Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
openNewChannel = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SAVE_NEW_CHANNEL),
|
|
|
|
mergeMap((action: RTLActions.SaveNewChannel) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.CHANNELS_API, {
|
|
|
|
node_pubkey: action.payload.selectedPeerPubkey, local_funding_amount: action.payload.fundingAmount, private: action.payload.private,
|
|
|
|
trans_type: action.payload.transType, trans_type_value: action.payload.transTypeValue, spend_unconfirmed: action.payload.spendUnconfirmed
|
|
|
|
})
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('blockchain'));
|
|
|
|
this.store.dispatch(new RTLActions.FetchChannels({ routeParam: 'all' }));
|
|
|
|
this.store.dispatch(new RTLActions.BackupChannels({ channelPoint: 'ALL', showMessage: 'Channel Added Successfully!' }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.FETCH_CHANNELS,
|
|
|
|
payload: { routeParam: 'pending', channelStatus: '' }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Open Channel Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
updateChannel = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.UPDATE_CHANNELS),
|
|
|
|
mergeMap((action: RTLActions.UpdateChannels) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.CHANNELS_API + '/chanPolicy',
|
|
|
|
{ baseFeeMsat: action.payload.baseFeeMsat, feeRate: action.payload.feeRate, timeLockDelta: action.payload.timeLockDelta, chanPoint: action.payload.chanPoint })
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: 'Channel Updated Successfully!' } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.FETCH_CHANNELS,
|
|
|
|
payload: { routeParam: 'all', channelStatus: '' }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Update Channel Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
closeChannel = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.CLOSE_CHANNEL),
|
|
|
|
mergeMap((action: RTLActions.CloseChannel) => {
|
|
|
|
return this.httpClient.delete(this.CHILD_API_URL + environment.CHANNELS_API + '/' + action.payload.channelPoint + '?force=' + action.payload.forcibly)
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('channels'));
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('blockchain'));
|
|
|
|
this.store.dispatch(new RTLActions.FetchChannels({ routeParam: 'all' }));
|
|
|
|
if (action.payload.forcibly) {
|
|
|
|
this.store.dispatch(new RTLActions.FetchChannels({ routeParam: 'pending' }));
|
|
|
|
} else {
|
|
|
|
this.store.dispatch(new RTLActions.FetchChannels({ routeParam: 'closed' }));
|
|
|
|
}
|
|
|
|
this.store.dispatch(new RTLActions.BackupChannels({ channelPoint: 'ALL', showMessage: 'Channel Closed Successfully!' }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.REMOVE_CHANNEL,
|
|
|
|
payload: { channelPoint: action.payload.channelPoint }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Unable to Close Channel. Try again later.',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error.message })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
backupChannels = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.BACKUP_CHANNELS),
|
|
|
|
mergeMap((action: RTLActions.BackupChannels) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('BackupChannels'));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.CHANNELS_BACKUP_API + '/' + action.payload.channelPoint)
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: action.payload.showMessage + ' ' + postRes.message } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.BACKUP_CHANNELS_RES,
|
|
|
|
payload: postRes.message
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'BackupChannels', code: err.status, message: err.error.error }));
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: action.payload.showMessage + ' ' + 'Unable to Backup Channel. Try again later.',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.message })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
verifyChannels = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.VERIFY_CHANNELS),
|
|
|
|
mergeMap((action: RTLActions.VerifyChannels) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('VerifyChannels'));
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.CHANNELS_BACKUP_API + '/verify/' + action.payload.channelPoint, {})
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: postRes.message } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.VERIFY_CHANNELS_RES,
|
|
|
|
payload: postRes.message
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'VerifyChannels', code: err.status, message: err.error.error }));
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Unable to Verify Channel. Try again later.',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.message })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
restoreChannels = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.RESTORE_CHANNELS),
|
|
|
|
mergeMap((action: RTLActions.RestoreChannels) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('RestoreChannels'));
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.CHANNELS_BACKUP_API + '/restore/' + action.payload.channelPoint, {})
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'SUCCESS', titleMessage: postRes.message } }));
|
|
|
|
return {
|
|
|
|
type: RTLActions.RESTORE_CHANNELS_RES,
|
|
|
|
payload: postRes.message
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'RestoreChannels', code: err.status, message: err.error.error }));
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Unable to Restore Channel. Try again later.',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.message })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
fetchFees = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_FEES),
|
|
|
|
mergeMap((action: RTLActions.FetchFees) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchFees'));
|
|
|
|
return this.httpClient.get<Fees>(this.CHILD_API_URL + environment.FEES_API);
|
|
|
|
}),
|
|
|
|
map((fees) => {
|
|
|
|
this.logger.info(fees);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_FEES,
|
|
|
|
payload: (undefined !== fees) ? fees : {}
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchFees', code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
balanceFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_BALANCE),
|
|
|
|
mergeMap((action: RTLActions.FetchBalance) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchBalance/' + action.payload));
|
|
|
|
return this.httpClient.get<Balance>(this.CHILD_API_URL + environment.BALANCE_API + '/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((res: any) => {
|
|
|
|
if (action.payload === 'channels') {
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('blockchain'));
|
|
|
|
}
|
|
|
|
this.logger.info(res);
|
|
|
|
const emptyRes = (action.payload === 'channels') ? { balance: '', btc_balance: '' } : { total_balance: '', btc_total_balance: '' };
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_BALANCE,
|
|
|
|
payload: (undefined !== res) ? { target: action.payload, balance: res } : { target: action.payload, balance: emptyRes }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchBalance/' + action.payload, code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
networkInfoFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_NETWORK),
|
|
|
|
mergeMap((action: RTLActions.FetchNetwork) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchNetwork'));
|
|
|
|
return this.httpClient.get<NetworkInfo>(this.CHILD_API_URL + environment.NETWORK_API + '/info');
|
|
|
|
}),
|
|
|
|
map((networkInfo) => {
|
|
|
|
this.logger.info(networkInfo);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_NETWORK,
|
|
|
|
payload: (undefined !== networkInfo) ? networkInfo : {}
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchNetwork', code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
channelsFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_CHANNELS),
|
|
|
|
mergeMap((action: RTLActions.FetchChannels) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchChannels/' + action.payload.routeParam));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.CHANNELS_API + '/' + action.payload.routeParam)
|
|
|
|
.pipe(
|
|
|
|
map((channels: any) => {
|
|
|
|
this.logger.info(channels);
|
|
|
|
if (action.payload.routeParam === 'pending') {
|
|
|
|
let pendingChannels = -1;
|
|
|
|
if (channels) {
|
|
|
|
pendingChannels = 0;
|
|
|
|
if (channels.pending_closing_channels) {
|
|
|
|
pendingChannels = pendingChannels + channels.pending_closing_channels.length;
|
|
|
|
}
|
|
|
|
if (channels.pending_force_closing_channels) {
|
|
|
|
pendingChannels = pendingChannels + channels.pending_force_closing_channels.length;
|
|
|
|
}
|
|
|
|
if (channels.pending_open_channels) {
|
|
|
|
pendingChannels = pendingChannels + channels.pending_open_channels.length;
|
|
|
|
}
|
|
|
|
if (channels.waiting_close_channels) {
|
|
|
|
pendingChannels = pendingChannels + channels.waiting_close_channels.length;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.store.dispatch(new RTLActions.SetNodePendingChannelsData(pendingChannels));
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_PENDING_CHANNELS,
|
|
|
|
payload: (undefined !== channels) ? { channels: channels, pendingChannels: pendingChannels } : {channels: {}, pendingChannels: pendingChannels}
|
|
|
|
};
|
|
|
|
} else if (action.payload.routeParam === 'closed') {
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_CLOSED_CHANNELS,
|
|
|
|
payload: (undefined !== channels && undefined !== channels.channels && channels.channels.length > 0) ? channels.channels : []
|
|
|
|
};
|
|
|
|
} else if (action.payload.routeParam === 'all') {
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_CHANNELS,
|
|
|
|
payload: (undefined !== channels && undefined !== channels.channels && channels.channels.length > 0) ? channels.channels : []
|
|
|
|
};
|
|
|
|
}
|
|
|
|
},
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchChannels/' + action.payload.routeParam, code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
})
|
|
|
|
));
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
invoicesFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_INVOICES),
|
|
|
|
mergeMap((action: RTLActions.FetchInvoices) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchInvoices'));
|
|
|
|
const num_max_invoices = (action.payload.num_max_invoices) ? action.payload.num_max_invoices : 100;
|
|
|
|
const index_offset = (action.payload.index_offset) ? action.payload.index_offset : 0;
|
|
|
|
const reversed = (action.payload.reversed) ? action.payload.reversed : false;
|
|
|
|
return this.httpClient.get<ListInvoices>(this.CHILD_API_URL + environment.INVOICES_API + '?num_max_invoices=' + num_max_invoices + '&index_offset=' + index_offset + '&reversed=' + reversed)
|
|
|
|
.pipe(map((res: ListInvoices) => {
|
|
|
|
this.logger.info(res);
|
|
|
|
if (action.payload.reversed && !action.payload.index_offset) {
|
|
|
|
this.store.dispatch(new RTLActions.SetTotalInvoices(+res.last_index_offset));
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_INVOICES,
|
|
|
|
payload: res
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchInvoices', code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
}));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
transactionsFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_TRANSACTIONS),
|
|
|
|
mergeMap((action: RTLActions.FetchTransactions) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchTransactions'));
|
|
|
|
return this.httpClient.get<Transaction[]>(this.CHILD_API_URL + environment.TRANSACTIONS_API);
|
|
|
|
}),
|
|
|
|
map((transactions) => {
|
|
|
|
this.logger.info(transactions);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_TRANSACTIONS,
|
|
|
|
payload: (undefined !== transactions && transactions.length > 0) ? transactions : []
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchTransactions', code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
paymentsFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_PAYMENTS),
|
|
|
|
mergeMap((action: RTLActions.FetchPayments) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('FetchPayments'));
|
|
|
|
return this.httpClient.get<Payment[]>(this.CHILD_API_URL + environment.PAYMENTS_API);
|
|
|
|
}),
|
|
|
|
map((payments) => {
|
|
|
|
this.logger.info(payments);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_PAYMENTS,
|
|
|
|
payload: (undefined !== payments && null != payments) ? payments : []
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.logger.error(err);
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'FetchPayments', code: err.status, message: err.error.error }));
|
|
|
|
return of();
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
decodePayment = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.DECODE_PAYMENT),
|
|
|
|
mergeMap((action: RTLActions.DecodePayment) => {
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.PAYREQUEST_API + '/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((decodedPayment) => {
|
|
|
|
this.logger.info(decodedPayment);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_DECODED_PAYMENT,
|
|
|
|
payload: (undefined !== decodedPayment) ? decodedPayment : {}
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Decode Payment Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.PAYREQUEST_API + '/' + action.payload })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
setDecodedPayment = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_DECODED_PAYMENT),
|
|
|
|
map((action: RTLActions.SetDecodedPayment) => {
|
|
|
|
this.logger.info(action.payload);
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
sendPayment = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SEND_PAYMENT),
|
|
|
|
withLatestFrom(this.store.select('root')),
|
|
|
|
mergeMap(([action, store]: [RTLActions.SendPayment, any]) => {
|
|
|
|
let queryHeaders = {};
|
|
|
|
if (action.payload[2]) {
|
|
|
|
queryHeaders = { paymentDecoded: action.payload[1] };
|
|
|
|
} else {
|
|
|
|
queryHeaders = { paymentReq: action.payload[0] };
|
|
|
|
}
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.CHANNELS_API + '/transactions', queryHeaders)
|
|
|
|
.pipe(
|
|
|
|
map((sendRes: any) => {
|
|
|
|
this.logger.info(sendRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
if (sendRes.payment_error) {
|
|
|
|
this.logger.error('Error: ' + sendRes.payment_error);
|
|
|
|
return of({
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Send Payment Failed',
|
|
|
|
message: JSON.stringify(
|
|
|
|
{ code: sendRes.payment_error.status, Message: sendRes.payment_error.error.message, URL: this.CHILD_API_URL + environment.CHANNELS_API + '/transactions/' + action.payload[0] }
|
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
const confirmationMsg = { 'Destination': action.payload[1].destination, 'Timestamp': action.payload[1].timestamp_str, 'Expiry': action.payload[1].expiry };
|
|
|
|
confirmationMsg['Amount (' + ((undefined === store.nodeData.smaller_currency_unit) ?
|
|
|
|
'Sats' : store.nodeData.smaller_currency_unit) + ')'] = action.payload[1].num_satoshis;
|
|
|
|
const msg = {};
|
|
|
|
msg['Total Fee (' + ((undefined === store.nodeData.smaller_currency_unit) ? 'Sats' : store.nodeData.smaller_currency_unit) + ')'] =
|
|
|
|
(sendRes.payment_route.total_fees_msat / 1000);
|
|
|
|
Object.assign(msg, confirmationMsg);
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({
|
|
|
|
width: '70%',
|
|
|
|
data: { type: 'SUCCESS', titleMessage: 'Payment Sent Successfully!', message: JSON.stringify(msg) }
|
|
|
|
}));
|
|
|
|
this.store.dispatch(new RTLActions.FetchChannels({ routeParam: 'all' }));
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('channels'));
|
|
|
|
this.store.dispatch(new RTLActions.FetchPayments());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_DECODED_PAYMENT,
|
|
|
|
payload: {}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Send Payment Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.CHANNELS_API + '/transactions/' + action.payload[0] })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
graphNodeFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.FETCH_GRAPH_NODE),
|
|
|
|
mergeMap((action: RTLActions.FetchGraphNode) => {
|
|
|
|
return this.httpClient.get<GraphNode>(this.CHILD_API_URL + environment.NETWORK_API + '/node/' + action.payload)
|
|
|
|
.pipe(map((graphNode: any) => {
|
|
|
|
this.logger.info(graphNode);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_GRAPH_NODE,
|
|
|
|
payload: (undefined !== graphNode) ? graphNode : {}
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Get Node Address Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
setGraphNode = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_GRAPH_NODE),
|
|
|
|
map((action: RTLActions.SetGraphNode) => {
|
|
|
|
this.logger.info(action.payload);
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
getNewAddress = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.GET_NEW_ADDRESS),
|
|
|
|
mergeMap((action: RTLActions.GetNewAddress) => {
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.NEW_ADDRESS_API + '?type=' + action.payload.addressId)
|
|
|
|
.pipe(map((newAddress: any) => {
|
|
|
|
this.logger.info(newAddress);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_NEW_ADDRESS,
|
|
|
|
payload: (undefined !== newAddress && undefined !== newAddress.address) ? newAddress.address : {}
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Generate New Address Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.NEW_ADDRESS_API + '?type=' + action.payload.addressId })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}));
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
setNewAddress = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_NEW_ADDRESS),
|
|
|
|
map((action: RTLActions.SetNewAddress) => {
|
|
|
|
this.logger.info(action.payload);
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
SetChannelTransaction = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_CHANNEL_TRANSACTION),
|
|
|
|
mergeMap((action: RTLActions.SetChannelTransaction) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('SetChannelTransaction'));
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.TRANSACTIONS_API,
|
|
|
|
{ amount: action.payload.amount, address: action.payload.address, sendAll: action.payload.sendAll, fees: action.payload.fees, blocks: action.payload.blocks }
|
|
|
|
)
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.FetchBalance('blockchain'));
|
|
|
|
return {
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: { data: { type: 'SUCCESS', titleMessage: 'Fund Sent Successfully!' } }
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'SetChannelTransaction', code: err.status, message: err.error.error }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Sending Fund Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}));
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
fetchForwardingHistory = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.GET_FORWARDING_HISTORY),
|
|
|
|
mergeMap((action: RTLActions.GetForwardingHistory) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('GetForwardingHistory'));
|
|
|
|
const queryHeaders: SwitchReq = {
|
|
|
|
num_max_events: action.payload.num_max_events, index_offset: action.payload.index_offset, end_time: action.payload.end_time, start_time: action.payload.start_time
|
|
|
|
};
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.SWITCH_API, queryHeaders)
|
|
|
|
.pipe(
|
|
|
|
map((fhRes: any) => {
|
|
|
|
this.logger.info(fhRes);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_FORWARDING_HISTORY,
|
|
|
|
payload: fhRes
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'GetForwardingHistory', code: err.status, message: err.error.error }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Get Forwarding History Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.SWITCH_API })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
queryRoutesFetch = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.GET_QUERY_ROUTES),
|
|
|
|
mergeMap((action: RTLActions.GetQueryRoutes) => {
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.NETWORK_API + '/routes/' + action.payload.destPubkey + '/' + action.payload.amount)
|
|
|
|
.pipe(
|
|
|
|
map((qrRes: any) => {
|
|
|
|
this.logger.info(qrRes);
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_QUERY_ROUTES,
|
|
|
|
payload: qrRes
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.SetQueryRoutes({}));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Get Query Routes Failed',
|
|
|
|
message: JSON.stringify({ code: err.status, Message: err.error.error.error, URL: this.CHILD_API_URL + environment.NETWORK_API })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
setQueryRoutes = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_QUERY_ROUTES),
|
|
|
|
map((action: RTLActions.SetQueryRoutes) => {
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
genSeed = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.GEN_SEED),
|
|
|
|
mergeMap((action: RTLActions.GenSeed) => {
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.WALLET_API + '/genseed/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((postRes: any) => {
|
|
|
|
this.logger.info('Generated GenSeed!');
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.GEN_SEED_RESPONSE,
|
|
|
|
payload: postRes.cipher_seed_mnemonic
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'ERROR', titleMessage: err.error.message + ' ' + err.error.error.code } }));
|
|
|
|
this.logger.error(err.error.error);
|
|
|
|
return of();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
genSeedResponse = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.GEN_SEED_RESPONSE),
|
|
|
|
map((action: RTLActions.GenSeedResponse) => {
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
initWalletRes = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.INIT_WALLET_RESPONSE),
|
|
|
|
map((action: RTLActions.InitWalletResponse) => {
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
initWallet = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.INIT_WALLET),
|
|
|
|
mergeMap((action: RTLActions.InitWallet) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.WALLET_API + '/initwallet',
|
|
|
|
{
|
|
|
|
wallet_password: action.payload.pwd,
|
|
|
|
cipher_seed_mnemonic: action.payload.cipher ? action.payload.cipher : '',
|
|
|
|
aezeed_passphrase: action.payload.passphrase ? action.payload.passphrase : ''
|
|
|
|
})
|
|
|
|
.pipe(
|
|
|
|
map((postRes) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.INIT_WALLET_RESPONSE,
|
|
|
|
payload: postRes
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'ERROR', titleMessage: err.error.error } }));
|
|
|
|
this.logger.error(err.error.error);
|
|
|
|
return of();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
unlockWallet = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.UNLOCK_WALLET),
|
|
|
|
mergeMap((action: RTLActions.UnlockWallet) => {
|
|
|
|
return this.httpClient.post(this.CHILD_API_URL + environment.WALLET_API + '/unlockwallet', { wallet_password: action.payload.pwd })
|
|
|
|
.pipe(
|
|
|
|
map((postRes) => {
|
|
|
|
this.logger.info(postRes);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenSpinner('Initializing Node...'));
|
|
|
|
this.logger.info('Successfully Unlocked!');
|
|
|
|
sessionStorage.setItem('lndUnlocked', 'true');
|
|
|
|
setTimeout(() => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.logger.info('Successfully Initialized!');
|
|
|
|
this.store.dispatch(new RTLActions.InitAppData());
|
|
|
|
this.router.navigate(['/lnd/']);
|
|
|
|
}, 1000 * 90);
|
|
|
|
return of({});
|
|
|
|
}),
|
|
|
|
catchError((err) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.OpenAlert({ width: '70%', data: { type: 'ERROR', titleMessage: err.error.error } }));
|
|
|
|
this.logger.error(err.error.error);
|
|
|
|
return of();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
));
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
peerLookup = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.PEER_LOOKUP),
|
|
|
|
mergeMap((action: RTLActions.PeerLookup) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('Lookup'));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.NETWORK_API + '/node/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((resPeer) => {
|
|
|
|
this.logger.info(resPeer);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_LOOKUP,
|
|
|
|
payload: resPeer
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'Lookup', code: err.status, message: err.error.message }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Peer Lookup Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.NETWORK_API + '/node/' + action.payload })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
channelLookup = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.CHANNEL_LOOKUP),
|
|
|
|
mergeMap((action: RTLActions.ChannelLookup) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('Lookup'));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.NETWORK_API + '/edge/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((resChannel) => {
|
|
|
|
this.logger.info(resChannel);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_LOOKUP,
|
|
|
|
payload: resChannel
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'Lookup', code: err.status, message: err.error.message }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Channel Lookup Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.NETWORK_API + '/edge/' + action.payload })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect()
|
|
|
|
invoiceLookup = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.INVOICE_LOOKUP),
|
|
|
|
mergeMap((action: RTLActions.InvoiceLookup) => {
|
|
|
|
this.store.dispatch(new RTLActions.ClearEffectErrorLnd('Lookup'));
|
|
|
|
return this.httpClient.get(this.CHILD_API_URL + environment.INVOICES_API + '/' + action.payload)
|
|
|
|
.pipe(
|
|
|
|
map((resInvoice) => {
|
|
|
|
this.logger.info(resInvoice);
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
return {
|
|
|
|
type: RTLActions.SET_LOOKUP,
|
|
|
|
payload: resInvoice
|
|
|
|
};
|
|
|
|
}),
|
|
|
|
catchError((err: any) => {
|
|
|
|
this.store.dispatch(new RTLActions.CloseSpinner());
|
|
|
|
this.store.dispatch(new RTLActions.EffectErrorLnd({ action: 'Lookup', code: err.status, message: err.error.message }));
|
|
|
|
this.logger.error(err);
|
|
|
|
return of(
|
|
|
|
{
|
|
|
|
type: RTLActions.OPEN_ALERT,
|
|
|
|
payload: {
|
|
|
|
width: '70%', data: {
|
|
|
|
type: 'ERROR', titleMessage: 'Invoice Lookup Failed',
|
|
|
|
message: JSON.stringify({ Code: err.status, Message: err.error.error, URL: this.CHILD_API_URL + environment.INVOICES_API + '/' + action.payload })
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
@Effect({ dispatch: false })
|
|
|
|
setLookup = this.actions$.pipe(
|
|
|
|
ofType(RTLActions.SET_LOOKUP),
|
|
|
|
map((action: RTLActions.SetLookup) => {
|
|
|
|
this.logger.info(action.payload);
|
|
|
|
return action.payload;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
ngOnDestroy() {
|
|
|
|
this.unSubs.forEach(completeSub => {
|
|
|
|
completeSub.next();
|
|
|
|
completeSub.complete();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|