Merge pull request #957 from lbryio/issue/952
Refactor lbryuri.js into separate named exports
This commit is contained in:
commit
c975454501
23 changed files with 80 additions and 88 deletions
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri.js';
|
import { normalizeURI } from 'lbryURI';
|
||||||
import CardMedia from 'component/cardMedia';
|
import CardMedia from 'component/cardMedia';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
import { TruncatedText } from 'component/common';
|
import { TruncatedText } from 'component/common';
|
||||||
|
@ -57,7 +57,7 @@ class FileCard extends React.PureComponent {
|
||||||
rewardedContentClaimIds,
|
rewardedContentClaimIds,
|
||||||
} = this.props;
|
} = this.props;
|
||||||
|
|
||||||
const uri = lbryuri.normalize(this.props.uri);
|
const uri = normalizeURI(this.props.uri);
|
||||||
const title = metadata && metadata.title ? metadata.title : uri;
|
const title = metadata && metadata.title ? metadata.title : uri;
|
||||||
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
|
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
|
||||||
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;
|
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri.js';
|
import { buildURI } from 'lbryURI';
|
||||||
import FormField from 'component/formField';
|
import FormField from 'component/formField';
|
||||||
import FileTile from 'component/fileTile';
|
import FileTile from 'component/fileTile';
|
||||||
import { BusyMessage } from 'component/common.js';
|
import { BusyMessage } from 'component/common.js';
|
||||||
|
@ -76,7 +76,7 @@ class FileList extends React.PureComponent {
|
||||||
uriParams.claimId = fileInfo.claim_id;
|
uriParams.claimId = fileInfo.claim_id;
|
||||||
uriParams.name = fileInfo.name;
|
uriParams.name = fileInfo.name;
|
||||||
}
|
}
|
||||||
const uri = lbryuri.build(uriParams);
|
const uri = buildURI(uriParams);
|
||||||
|
|
||||||
content.push(
|
content.push(
|
||||||
<FileTile
|
<FileTile
|
||||||
|
|
|
@ -3,7 +3,7 @@ import FileTile from 'component/fileTile';
|
||||||
import ChannelTile from 'component/channelTile';
|
import ChannelTile from 'component/channelTile';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
import { BusyMessage } from 'component/common.js';
|
import { BusyMessage } from 'component/common.js';
|
||||||
import lbryuri from 'lbryuri';
|
import { parseURI } from 'lbryURI';
|
||||||
|
|
||||||
const SearchNoResults = props => {
|
const SearchNoResults = props => {
|
||||||
const { query } = props;
|
const { query } = props;
|
||||||
|
@ -45,7 +45,7 @@ class FileListSearch extends React.PureComponent {
|
||||||
{uris && uris.length
|
{uris && uris.length
|
||||||
? uris.map(
|
? uris.map(
|
||||||
uri =>
|
uri =>
|
||||||
lbryuri.parse(uri).name[0] === '@' ? (
|
parseURI(uri).name[0] === '@' ? (
|
||||||
<ChannelTile key={uri} uri={uri} />
|
<ChannelTile key={uri} uri={uri} />
|
||||||
) : (
|
) : (
|
||||||
<FileTile key={uri} uri={uri} />
|
<FileTile key={uri} uri={uri} />
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import * as icons from 'constants/icons';
|
import * as icons from 'constants/icons';
|
||||||
import lbryuri from 'lbryuri.js';
|
import { normalizeURI, isURIClaimable, parseURI } from 'lbryURI';
|
||||||
import CardMedia from 'component/cardMedia';
|
import CardMedia from 'component/cardMedia';
|
||||||
import { TruncatedText } from 'component/common.js';
|
import { TruncatedText } from 'component/common.js';
|
||||||
import FilePrice from 'component/filePrice';
|
import FilePrice from 'component/filePrice';
|
||||||
|
@ -65,11 +65,11 @@ class FileTile extends React.PureComponent {
|
||||||
fileInfo,
|
fileInfo,
|
||||||
} = this.props;
|
} = this.props;
|
||||||
|
|
||||||
const uri = lbryuri.normalize(this.props.uri);
|
const uri = normalizeURI(this.props.uri);
|
||||||
const isClaimed = !!claim;
|
const isClaimed = !!claim;
|
||||||
const isClaimable = lbryuri.isClaimable(uri);
|
const isClaimable = isURIClaimable(uri);
|
||||||
const title =
|
const title =
|
||||||
isClaimed && metadata && metadata.title ? metadata.title : lbryuri.parse(uri).contentName;
|
isClaimed && metadata && metadata.title ? metadata.title : parseURI(uri).contentName;
|
||||||
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
|
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
|
||||||
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;
|
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;
|
||||||
const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id);
|
const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri';
|
import { isNameValid } from 'lbryURI';
|
||||||
import { FormRow } from 'component/form.js';
|
import { FormRow } from 'component/form.js';
|
||||||
import { BusyMessage } from 'component/common';
|
import { BusyMessage } from 'component/common';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
|
@ -29,7 +29,7 @@ class ChannelSection extends React.PureComponent {
|
||||||
? event.target.value
|
? event.target.value
|
||||||
: `@${event.target.value}`;
|
: `@${event.target.value}`;
|
||||||
|
|
||||||
if (newChannelName.length > 1 && !lbryuri.isValidName(newChannelName.substr(1), false)) {
|
if (newChannelName.length > 1 && !isNameValid(newChannelName.substr(1), false)) {
|
||||||
this.refs.newChannelName.showError(
|
this.refs.newChannelName.showError(
|
||||||
__('LBRY channel names must contain only letters, numbers and dashes.')
|
__('LBRY channel names must contain only letters, numbers and dashes.')
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbry from 'lbry';
|
import lbry from 'lbry';
|
||||||
import lbryuri from 'lbryuri';
|
import { isNameValid, buildURI, regexInvalidURI } from 'lbryURI';
|
||||||
import FormField from 'component/formField';
|
import FormField from 'component/formField';
|
||||||
import { Form, FormRow, Submit } from 'component/form.js';
|
import { Form, FormRow, Submit } from 'component/form.js';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
|
@ -245,7 +245,7 @@ class PublishForm extends React.PureComponent {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!lbryuri.isValidName(rawName, false)) {
|
if (!isNameValid(rawName, false)) {
|
||||||
this.refs.name.showError(__('LBRY names must contain only letters, numbers and dashes.'));
|
this.refs.name.showError(__('LBRY names must contain only letters, numbers and dashes.'));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -254,7 +254,7 @@ class PublishForm extends React.PureComponent {
|
||||||
if (this.state.channel !== 'anonymous') channel = this.state.channel;
|
if (this.state.channel !== 'anonymous') channel = this.state.channel;
|
||||||
|
|
||||||
const name = rawName.toLowerCase();
|
const name = rawName.toLowerCase();
|
||||||
const uri = lbryuri.build({ contentName: name, channelName: channel });
|
const uri = buildURI({ contentName: name, channelName: channel });
|
||||||
this.setState({
|
this.setState({
|
||||||
rawName,
|
rawName,
|
||||||
name,
|
name,
|
||||||
|
@ -446,7 +446,7 @@ class PublishForm extends React.PureComponent {
|
||||||
const extension = path.extname(fileName);
|
const extension = path.extname(fileName);
|
||||||
|
|
||||||
fileName = path.basename(fileName, extension);
|
fileName = path.basename(fileName, extension);
|
||||||
fileName = fileName.replace(lbryuri.REGEXP_INVALID_URI, '');
|
fileName = fileName.replace(regexInvalidURI, '');
|
||||||
return fileName;
|
return fileName;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ import LinkTransaction from 'component/linkTransaction';
|
||||||
import { CreditAmount } from 'component/common';
|
import { CreditAmount } from 'component/common';
|
||||||
import DateTime from 'component/dateTime';
|
import DateTime from 'component/dateTime';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
import lbryuri from 'lbryuri';
|
import { buildURI } from 'lbryURI';
|
||||||
import * as txnTypes from 'constants/transaction_types';
|
import * as txnTypes from 'constants/transaction_types';
|
||||||
|
|
||||||
class TransactionListItem extends React.PureComponent {
|
class TransactionListItem extends React.PureComponent {
|
||||||
|
@ -74,7 +74,7 @@ class TransactionListItem extends React.PureComponent {
|
||||||
<Link
|
<Link
|
||||||
className="button-text"
|
className="button-text"
|
||||||
navigate="/show"
|
navigate="/show"
|
||||||
navigateParams={{ uri: lbryuri.build({ name, claimId }) }}
|
navigateParams={{ uri: buildURI({ name, claimId }) }}
|
||||||
>
|
>
|
||||||
{name}
|
{name}
|
||||||
</Link>
|
</Link>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri';
|
import { normalizeURI } from 'lbryURI';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import { doResolveUri } from 'redux/actions/content';
|
import { doResolveUri } from 'redux/actions/content';
|
||||||
import { makeSelectIsUriResolving } from 'redux/selectors/content';
|
import { makeSelectIsUriResolving } from 'redux/selectors/content';
|
||||||
|
@ -9,7 +9,7 @@ import UriIndicator from './view';
|
||||||
const select = (state, props) => ({
|
const select = (state, props) => ({
|
||||||
claim: makeSelectClaimForUri(props.uri)(state),
|
claim: makeSelectClaimForUri(props.uri)(state),
|
||||||
isResolvingUri: makeSelectIsUriResolving(props.uri)(state),
|
isResolvingUri: makeSelectIsUriResolving(props.uri)(state),
|
||||||
uri: lbryuri.normalize(props.uri),
|
uri: normalizeURI(props.uri),
|
||||||
});
|
});
|
||||||
|
|
||||||
const perform = dispatch => ({
|
const perform = dispatch => ({
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Icon from 'component/icon';
|
import Icon from 'component/icon';
|
||||||
import Link from 'component/link';
|
import Link from 'component/link';
|
||||||
import lbryuri from 'lbryuri';
|
import { buildURI } from 'lbryURI';
|
||||||
import classnames from 'classnames';
|
import classnames from 'classnames';
|
||||||
|
|
||||||
class UriIndicator extends React.PureComponent {
|
class UriIndicator extends React.PureComponent {
|
||||||
|
@ -49,7 +49,7 @@ class UriIndicator extends React.PureComponent {
|
||||||
|
|
||||||
if (signatureIsValid) {
|
if (signatureIsValid) {
|
||||||
modifier = 'valid';
|
modifier = 'valid';
|
||||||
channelLink = link ? lbryuri.build({ channelName, claimId: channelClaimId }, false) : false;
|
channelLink = link ? buildURI({ channelName, claimId: channelClaimId }, false) : false;
|
||||||
} else {
|
} else {
|
||||||
icon = 'icon-times-circle';
|
icon = 'icon-times-circle';
|
||||||
modifier = 'invalid';
|
modifier = 'invalid';
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Form, FormRow, Submit } from 'component/form';
|
import { Form, FormRow, Submit } from 'component/form';
|
||||||
import lbryuri from 'lbryuri';
|
import { regexAddress } from 'lbryURI';
|
||||||
|
|
||||||
class WalletSend extends React.PureComponent {
|
class WalletSend extends React.PureComponent {
|
||||||
handleSubmit() {
|
handleSubmit() {
|
||||||
|
@ -42,7 +42,7 @@ class WalletSend extends React.PureComponent {
|
||||||
size="60"
|
size="60"
|
||||||
onChange={setAddress}
|
onChange={setAddress}
|
||||||
value={address}
|
value={address}
|
||||||
regexp={lbryuri.REGEXP_ADDRESS}
|
regexp={regexAddress}
|
||||||
trim
|
trim
|
||||||
/>
|
/>
|
||||||
<div className="form-row-submit">
|
<div className="form-row-submit">
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { connect } from 'react-redux';
|
import { connect } from 'react-redux';
|
||||||
import lbryuri from 'lbryuri.js';
|
import { normalizeURI } from 'lbryURI.js';
|
||||||
import { selectWunderBarAddress, selectWunderBarIcon } from 'redux/selectors/search';
|
import { selectWunderBarAddress, selectWunderBarIcon } from 'redux/selectors/search';
|
||||||
import { doNavigate } from 'redux/actions/navigation';
|
import { doNavigate } from 'redux/actions/navigation';
|
||||||
import Wunderbar from './view';
|
import Wunderbar from './view';
|
||||||
|
@ -13,7 +13,7 @@ const select = state => ({
|
||||||
const perform = dispatch => ({
|
const perform = dispatch => ({
|
||||||
onSearch: query => dispatch(doNavigate('/search', { query })),
|
onSearch: query => dispatch(doNavigate('/search', { query })),
|
||||||
onSubmit: (query, extraParams) =>
|
onSubmit: (query, extraParams) =>
|
||||||
dispatch(doNavigate('/show', { uri: lbryuri.normalize(query), ...extraParams })),
|
dispatch(doNavigate('/show', { uri: normalizeURI(query), ...extraParams })),
|
||||||
});
|
});
|
||||||
|
|
||||||
export default connect(select, perform)(Wunderbar);
|
export default connect(select, perform)(Wunderbar);
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import lbryuri from 'lbryuri.js';
|
import { normalizeURI } from 'lbryURI';
|
||||||
import Icon from 'component/icon';
|
import Icon from 'component/icon';
|
||||||
import { parseQueryParams } from 'util/query_params';
|
import { parseQueryParams } from 'util/query_params';
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ class WunderBar extends React.PureComponent {
|
||||||
if (parts.length > 0) extraParams = parseQueryParams(parts.join(''));
|
if (parts.length > 0) extraParams = parseQueryParams(parts.join(''));
|
||||||
|
|
||||||
try {
|
try {
|
||||||
uri = lbryuri.normalize(value);
|
uri = normalizeURI(value);
|
||||||
this.setState({ value: uri });
|
this.setState({ value: uri });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
// then it's not a valid URL, so let's search
|
// then it's not a valid URL, so let's search
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
const CHANNEL_NAME_MIN_LEN = 1;
|
const channelNameMinLength = 1;
|
||||||
const CLAIM_ID_MAX_LEN = 40;
|
const claimIdMaxLength = 40;
|
||||||
|
|
||||||
const Lbryuri = {};
|
export const regexInvalidURI = /[^A-Za-z0-9-]/g;
|
||||||
|
export const regexAddress = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
|
||||||
Lbryuri.REGEXP_INVALID_URI = /[^A-Za-z0-9-]/g;
|
|
||||||
Lbryuri.REGEXP_ADDRESS = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parses a LBRY name into its component parts. Throws errors with user-friendly
|
* Parses a LBRY name into its component parts. Throws errors with user-friendly
|
||||||
|
@ -28,7 +26,7 @@ Lbryuri.REGEXP_ADDRESS = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
|
||||||
* - contentName (string): For anon claims, the name; for channel claims, the path
|
* - contentName (string): For anon claims, the name; for channel claims, the path
|
||||||
* - channelName (string, if present): Channel name without @
|
* - channelName (string, if present): Channel name without @
|
||||||
*/
|
*/
|
||||||
Lbryuri.parse = (uri, requireProto = false) => {
|
export function parseURI(URI, requireProto = false) {
|
||||||
// Break into components. Empty sub-matches are converted to null
|
// Break into components. Empty sub-matches are converted to null
|
||||||
const componentsRegex = new RegExp(
|
const componentsRegex = new RegExp(
|
||||||
'^((?:lbry://)?)' + // protocol
|
'^((?:lbry://)?)' + // protocol
|
||||||
|
@ -37,7 +35,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
|
||||||
'(/?)(.*)' // path separator, path
|
'(/?)(.*)' // path separator, path
|
||||||
);
|
);
|
||||||
const [proto, name, modSep, modVal, pathSep, path] = componentsRegex
|
const [proto, name, modSep, modVal, pathSep, path] = componentsRegex
|
||||||
.exec(uri)
|
.exec(URI)
|
||||||
.slice(1)
|
.slice(1)
|
||||||
.map(match => match || null);
|
.map(match => match || null);
|
||||||
|
|
||||||
|
@ -61,14 +59,14 @@ Lbryuri.parse = (uri, requireProto = false) => {
|
||||||
throw new Error(__('No channel name after @.'));
|
throw new Error(__('No channel name after @.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (channelName.length < CHANNEL_NAME_MIN_LEN) {
|
if (channelName.length < channelNameMinLength) {
|
||||||
throw new Error(__(`Channel names must be at least %s characters.`, CHANNEL_NAME_MIN_LEN));
|
throw new Error(__(`Channel names must be at least %s characters.`, channelNameMinLength));
|
||||||
}
|
}
|
||||||
|
|
||||||
contentName = path;
|
contentName = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const nameBadChars = (channelName || name).match(Lbryuri.REGEXP_INVALID_URI);
|
const nameBadChars = (channelName || name).match(regexInvalidURI);
|
||||||
if (nameBadChars) {
|
if (nameBadChars) {
|
||||||
throw new Error(
|
throw new Error(
|
||||||
__(
|
__(
|
||||||
|
@ -99,7 +97,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
|
||||||
|
|
||||||
if (
|
if (
|
||||||
claimId &&
|
claimId &&
|
||||||
(claimId.length > CLAIM_ID_MAX_LEN || !claimId.match(/^[0-9a-f]+$/)) &&
|
(claimId.length > claimIdMaxLength || !claimId.match(/^[0-9a-f]+$/)) &&
|
||||||
!claimId.match(/^pending/) // ought to be dropped when savePendingPublish drops hack
|
!claimId.match(/^pending/) // ought to be dropped when savePendingPublish drops hack
|
||||||
) {
|
) {
|
||||||
throw new Error(__(`Invalid claim ID %s.`, claimId));
|
throw new Error(__(`Invalid claim ID %s.`, claimId));
|
||||||
|
@ -119,7 +117,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
|
||||||
throw new Error(__('Only channel URIs may have a path.'));
|
throw new Error(__('Only channel URIs may have a path.'));
|
||||||
}
|
}
|
||||||
|
|
||||||
const pathBadChars = path.match(Lbryuri.REGEXP_INVALID_URI);
|
const pathBadChars = path.match(regexInvalidURI);
|
||||||
if (pathBadChars) {
|
if (pathBadChars) {
|
||||||
throw new Error(__(`Invalid character in path: %s`, pathBadChars.join(', ')));
|
throw new Error(__(`Invalid character in path: %s`, pathBadChars.join(', ')));
|
||||||
}
|
}
|
||||||
|
@ -140,17 +138,17 @@ Lbryuri.parse = (uri, requireProto = false) => {
|
||||||
...(claimId ? { claimId } : {}),
|
...(claimId ? { claimId } : {}),
|
||||||
...(path ? { path } : {}),
|
...(path ? { path } : {}),
|
||||||
};
|
};
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Takes an object in the same format returned by lbryuri.parse() and builds a URI.
|
* Takes an object in the same format returned by parse() and builds a URI.
|
||||||
*
|
*
|
||||||
* The channelName key will accept names with or without the @ prefix.
|
* The channelName key will accept names with or without the @ prefix.
|
||||||
*/
|
*/
|
||||||
Lbryuri.build = (uriObj, includeProto = true) => {
|
export function buildURI(URIObj, includeProto = true) {
|
||||||
const { claimId, claimSequence, bidPosition, contentName, channelName } = uriObj;
|
const { claimId, claimSequence, bidPosition, contentName, channelName } = URIObj;
|
||||||
|
|
||||||
let { name, path } = uriObj;
|
let { name, path } = URIObj;
|
||||||
|
|
||||||
if (channelName) {
|
if (channelName) {
|
||||||
const channelNameFormatted = channelName.startsWith('@') ? channelName : `@${channelName}`;
|
const channelNameFormatted = channelName.startsWith('@') ? channelName : `@${channelName}`;
|
||||||
|
@ -188,36 +186,35 @@ Lbryuri.build = (uriObj, includeProto = true) => {
|
||||||
(bidPosition ? `${bidPosition}` : '') +
|
(bidPosition ? `${bidPosition}` : '') +
|
||||||
(path ? `/${path}` : '')
|
(path ? `/${path}` : '')
|
||||||
);
|
);
|
||||||
};
|
}
|
||||||
|
|
||||||
/* Takes a parseable LBRY URI and converts it to standard, canonical format (currently this just
|
/* Takes a parseable LBRY URI and converts it to standard, canonical format */
|
||||||
* consists of adding the lbry:// prefix if needed) */
|
export function normalizeURI(URI) {
|
||||||
Lbryuri.normalize = uri => {
|
if (URI.match(/pending_claim/)) return URI;
|
||||||
if (uri.match(/pending_claim/)) return uri;
|
|
||||||
|
|
||||||
const { name, path, bidPosition, claimSequence, claimId } = Lbryuri.parse(uri);
|
const { name, path, bidPosition, claimSequence, claimId } = parseURI(URI);
|
||||||
return Lbryuri.build({ name, path, claimSequence, bidPosition, claimId });
|
return buildURI({ name, path, claimSequence, bidPosition, claimId });
|
||||||
};
|
}
|
||||||
|
|
||||||
Lbryuri.isValid = uri => {
|
export function isURIValid(URI) {
|
||||||
let parts;
|
let parts;
|
||||||
try {
|
try {
|
||||||
parts = Lbryuri.parse(Lbryuri.normalize(uri));
|
parts = parseURI(normalizeURI(URI));
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return parts && parts.name;
|
return parts && parts.name;
|
||||||
};
|
}
|
||||||
|
|
||||||
Lbryuri.isValidName = (name, checkCase = true) => {
|
export function isNameValid(name, checkCase = true) {
|
||||||
const regexp = new RegExp('^[a-z0-9-]+$', checkCase ? '' : 'i');
|
const regexp = new RegExp('^[a-z0-9-]+$', checkCase ? '' : 'i');
|
||||||
return regexp.test(name);
|
return regexp.test(name);
|
||||||
};
|
}
|
||||||
|
|
||||||
Lbryuri.isClaimable = uri => {
|
export function isURIClaimable(URI) {
|
||||||
let parts;
|
let parts;
|
||||||
try {
|
try {
|
||||||
parts = Lbryuri.parse(Lbryuri.normalize(uri));
|
parts = parseURI(normalizeURI(URI));
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -230,7 +227,4 @@ Lbryuri.isClaimable = uri => {
|
||||||
!parts.isChannel &&
|
!parts.isChannel &&
|
||||||
!parts.path
|
!parts.path
|
||||||
);
|
);
|
||||||
};
|
}
|
||||||
|
|
||||||
window.lbryuri = Lbryuri;
|
|
||||||
export default Lbryuri;
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri';
|
import { buildURI } from 'lbryURI';
|
||||||
import { BusyMessage } from 'component/common';
|
import { BusyMessage } from 'component/common';
|
||||||
import FileTile from 'component/fileTile';
|
import FileTile from 'component/fileTile';
|
||||||
import ReactPaginate from 'react-paginate';
|
import ReactPaginate from 'react-paginate';
|
||||||
|
@ -46,7 +46,7 @@ class ChannelPage extends React.PureComponent {
|
||||||
} = this.props;
|
} = this.props;
|
||||||
|
|
||||||
const { name, claim_id: claimId } = claim;
|
const { name, claim_id: claimId } = claim;
|
||||||
const subscriptionUri = lbryuri.build({ channelName: name, claimId }, false);
|
const subscriptionUri = buildURI({ channelName: name, claimId }, false);
|
||||||
|
|
||||||
let contentList;
|
let contentList;
|
||||||
if (fetching) {
|
if (fetching) {
|
||||||
|
@ -57,7 +57,7 @@ class ChannelPage extends React.PureComponent {
|
||||||
claimsInChannel.map(claim => (
|
claimsInChannel.map(claim => (
|
||||||
<FileTile
|
<FileTile
|
||||||
key={claim.claim_id}
|
key={claim.claim_id}
|
||||||
uri={lbryuri.build({
|
uri={buildURI({
|
||||||
name: claim.name,
|
name: claim.name,
|
||||||
claimId: claim.claim_id,
|
claimId: claim.claim_id,
|
||||||
})}
|
})}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import lbryuri from 'lbryuri';
|
import { normalizeURI } from 'lbryURI';
|
||||||
import FileCard from 'component/fileCard';
|
import FileCard from 'component/fileCard';
|
||||||
import { BusyMessage } from 'component/common.js';
|
import { BusyMessage } from 'component/common.js';
|
||||||
import Icon from 'component/icon';
|
import Icon from 'component/icon';
|
||||||
|
@ -212,7 +212,7 @@ export class FeaturedCategory extends React.PureComponent {
|
||||||
<div ref="rowitems" className="card-row__items">
|
<div ref="rowitems" className="card-row__items">
|
||||||
{names &&
|
{names &&
|
||||||
names.map(name => (
|
names.map(name => (
|
||||||
<FileCard key={name} displayStyle="card" uri={lbryuri.normalize(name)} />
|
<FileCard key={name} displayStyle="card" uri={normalizeURI(name)} />
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbry from 'lbry';
|
import lbry from 'lbry';
|
||||||
import lbryuri from 'lbryuri';
|
import { buildURI, normalizeURI } from 'lbryURI';
|
||||||
import Video from 'component/video';
|
import Video from 'component/video';
|
||||||
import { Thumbnail } from 'component/common';
|
import { Thumbnail } from 'component/common';
|
||||||
import FilePrice from 'component/filePrice';
|
import FilePrice from 'component/filePrice';
|
||||||
|
@ -65,7 +65,7 @@ class FilePage extends React.PureComponent {
|
||||||
|
|
||||||
let subscriptionUri;
|
let subscriptionUri;
|
||||||
if (channelName && channelClaimId) {
|
if (channelName && channelClaimId) {
|
||||||
subscriptionUri = lbryuri.build({ channelName, claimId: channelClaimId }, false);
|
subscriptionUri = buildURI({ channelName, claimId: channelClaimId }, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -86,7 +86,7 @@ class FilePage extends React.PureComponent {
|
||||||
<div className="card__title-identity">
|
<div className="card__title-identity">
|
||||||
{!fileInfo || fileInfo.written_bytes <= 0 ? (
|
{!fileInfo || fileInfo.written_bytes <= 0 ? (
|
||||||
<span style={{ float: 'right' }}>
|
<span style={{ float: 'right' }}>
|
||||||
<FilePrice uri={lbryuri.normalize(uri)} />
|
<FilePrice uri={normalizeURI(uri)} />
|
||||||
{isRewardContent && (
|
{isRewardContent && (
|
||||||
<span>
|
<span>
|
||||||
{' '}
|
{' '}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri';
|
import { isURIValid, normalizeURI } from 'lbryURI';
|
||||||
import FileTile from 'component/fileTile';
|
import FileTile from 'component/fileTile';
|
||||||
import FileListSearch from 'component/fileListSearch';
|
import FileListSearch from 'component/fileListSearch';
|
||||||
import { ToolTip } from 'component/tooltip.js';
|
import { ToolTip } from 'component/tooltip.js';
|
||||||
|
@ -10,7 +10,7 @@ class SearchPage extends React.PureComponent {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<main className="main--single-column">
|
<main className="main--single-column">
|
||||||
{lbryuri.isValid(query) ? (
|
{isURIValid(query) ? (
|
||||||
<section className="section-spaced">
|
<section className="section-spaced">
|
||||||
<h3 className="card-row__header">
|
<h3 className="card-row__header">
|
||||||
{__('Exact URL')}{' '}
|
{__('Exact URL')}{' '}
|
||||||
|
@ -20,7 +20,7 @@ class SearchPage extends React.PureComponent {
|
||||||
className="tooltip--header"
|
className="tooltip--header"
|
||||||
/>
|
/>
|
||||||
</h3>
|
</h3>
|
||||||
<FileTile uri={lbryuri.normalize(query)} showEmpty={FileTile.SHOW_EMPTY_PUBLISH} />
|
<FileTile uri={normalizeURI(query)} showEmpty={FileTile.SHOW_EMPTY_PUBLISH} />
|
||||||
</section>
|
</section>
|
||||||
) : (
|
) : (
|
||||||
''
|
''
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import lbryuri from 'lbryuri';
|
|
||||||
import { BusyMessage } from 'component/common';
|
import { BusyMessage } from 'component/common';
|
||||||
import ChannelPage from 'page/channel';
|
import ChannelPage from 'page/channel';
|
||||||
import FilePage from 'page/file';
|
import FilePage from 'page/file';
|
||||||
|
|
|
@ -4,7 +4,7 @@ import * as SETTINGS from 'constants/settings';
|
||||||
import { ipcRenderer } from 'electron';
|
import { ipcRenderer } from 'electron';
|
||||||
import Lbry from 'lbry';
|
import Lbry from 'lbry';
|
||||||
import Lbryio from 'lbryio';
|
import Lbryio from 'lbryio';
|
||||||
import Lbryuri from 'lbryuri';
|
import { normalizeURI, buildURI } from 'lbryURI';
|
||||||
import { doAlertError, doOpenModal } from 'redux/actions/app';
|
import { doAlertError, doOpenModal } from 'redux/actions/app';
|
||||||
import { doClaimEligiblePurchaseRewards } from 'redux/actions/rewards';
|
import { doClaimEligiblePurchaseRewards } from 'redux/actions/rewards';
|
||||||
import { selectBadgeNumber } from 'redux/selectors/app';
|
import { selectBadgeNumber } from 'redux/selectors/app';
|
||||||
|
@ -26,7 +26,7 @@ const DOWNLOAD_POLL_INTERVAL = 250;
|
||||||
|
|
||||||
export function doResolveUris(uris) {
|
export function doResolveUris(uris) {
|
||||||
return (dispatch, getState) => {
|
return (dispatch, getState) => {
|
||||||
const normalizedUris = uris.map(Lbryuri.normalize);
|
const normalizedUris = uris.map(normalizeURI);
|
||||||
const state = getState();
|
const state = getState();
|
||||||
|
|
||||||
// Filter out URIs that are already resolving
|
// Filter out URIs that are already resolving
|
||||||
|
@ -506,7 +506,7 @@ export function doAbandonClaim(txid, nout) {
|
||||||
claimId,
|
claimId,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
dispatch(doResolveUri(Lbryuri.build({ name, claimId })));
|
dispatch(doResolveUri(buildURI({ name, claimId })));
|
||||||
dispatch(doFetchClaimListMine());
|
dispatch(doFetchClaimListMine());
|
||||||
} else {
|
} else {
|
||||||
dispatch(doOpenModal(MODALS.TRANSACTION_FAILED));
|
dispatch(doOpenModal(MODALS.TRANSACTION_FAILED));
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import * as ACTIONS from 'constants/action_types';
|
import * as ACTIONS from 'constants/action_types';
|
||||||
import Lbryuri from 'lbryuri';
|
import { buildURI } from 'lbryURI';
|
||||||
import { doResolveUri } from 'redux/actions/content';
|
import { doResolveUri } from 'redux/actions/content';
|
||||||
import { doNavigate } from 'redux/actions/navigation';
|
import { doNavigate } from 'redux/actions/navigation';
|
||||||
import { selectCurrentPage } from 'redux/selectors/navigation';
|
import { selectCurrentPage } from 'redux/selectors/navigation';
|
||||||
|
@ -40,7 +40,7 @@ export function doSearch(rawQuery) {
|
||||||
const actions = [];
|
const actions = [];
|
||||||
|
|
||||||
data.forEach(result => {
|
data.forEach(result => {
|
||||||
const uri = Lbryuri.build({
|
const uri = buildURI({
|
||||||
name: result.name,
|
name: result.name,
|
||||||
claimId: result.claimId,
|
claimId: result.claimId,
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
import Lbryuri from 'lbryuri';
|
import { normalizeURI } from 'lbryURI';
|
||||||
import { makeSelectCurrentParam } from 'redux/selectors/navigation';
|
import { makeSelectCurrentParam } from 'redux/selectors/navigation';
|
||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
|
|
||||||
|
@ -32,7 +32,7 @@ export const selectAllClaimsByChannel = createSelector(
|
||||||
);
|
);
|
||||||
|
|
||||||
export const makeSelectClaimForUri = uri =>
|
export const makeSelectClaimForUri = uri =>
|
||||||
createSelector(selectClaimsByUri, claims => claims && claims[Lbryuri.normalize(uri)]);
|
createSelector(selectClaimsByUri, claims => claims && claims[normalizeURI(uri)]);
|
||||||
|
|
||||||
export const selectMyClaimsRaw = createSelector(selectState, state => state.myClaims);
|
export const selectMyClaimsRaw = createSelector(selectState, state => state.myClaims);
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ export const selectMyActiveClaims = createSelector(
|
||||||
);
|
);
|
||||||
|
|
||||||
export const makeSelectClaimIsMine = rawUri => {
|
export const makeSelectClaimIsMine = rawUri => {
|
||||||
const uri = Lbryuri.normalize(rawUri);
|
const uri = normalizeURI(rawUri);
|
||||||
return createSelector(
|
return createSelector(
|
||||||
selectClaimsByUri,
|
selectClaimsByUri,
|
||||||
selectMyActiveClaims,
|
selectMyActiveClaims,
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
import * as settings from 'constants/settings';
|
import * as settings from 'constants/settings';
|
||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import lbryuri from 'lbryuri';
|
|
||||||
import { makeSelectClaimForUri } from 'redux/selectors/claims';
|
import { makeSelectClaimForUri } from 'redux/selectors/claims';
|
||||||
|
|
||||||
const _selectState = state => state.media || {};
|
const _selectState = state => state.media || {};
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
import { createSelector } from 'reselect';
|
import { createSelector } from 'reselect';
|
||||||
import { parseQueryParams, toQueryString } from 'util/query_params';
|
import { parseQueryParams, toQueryString } from 'util/query_params';
|
||||||
import Lbryuri from 'lbryuri';
|
import { normalizeURI } from 'lbryURI';
|
||||||
|
|
||||||
export const selectState = state => state.navigation || {};
|
export const selectState = state => state.navigation || {};
|
||||||
|
|
||||||
|
@ -93,7 +93,7 @@ export const selectPageTitle = createSelector(
|
||||||
case 'developer':
|
case 'developer':
|
||||||
return __('Developer');
|
return __('Developer');
|
||||||
case 'show': {
|
case 'show': {
|
||||||
const parts = [Lbryuri.normalize(params.uri)];
|
const parts = [normalizeURI(params.uri)];
|
||||||
// If the params has any keys other than "uri"
|
// If the params has any keys other than "uri"
|
||||||
if (Object.keys(params).length > 1) {
|
if (Object.keys(params).length > 1) {
|
||||||
parts.push(toQueryString(Object.assign({}, params, { uri: null })));
|
parts.push(toQueryString(Object.assign({}, params, { uri: null })));
|
||||||
|
|
Loading…
Add table
Reference in a new issue