mirror of
https://github.com/bitwarden/android.git
synced 2025-01-12 19:27:37 +03:00
view updates
This commit is contained in:
parent
40598721f1
commit
7d6ec46ebe
5 changed files with 185 additions and 12 deletions
|
@ -28,7 +28,7 @@ namespace Bit.Core.Models.Domain
|
||||||
OrganizationUseTotp = obj.OrganizationUseTotp;
|
OrganizationUseTotp = obj.OrganizationUseTotp;
|
||||||
Edit = obj.Edit;
|
Edit = obj.Edit;
|
||||||
RevisionDate = obj.RevisionDate;
|
RevisionDate = obj.RevisionDate;
|
||||||
CollectionIds = obj.CollectionIds;
|
CollectionIds = new HashSet<string>(obj.CollectionIds);
|
||||||
LocalData = localData;
|
LocalData = localData;
|
||||||
|
|
||||||
switch(Type)
|
switch(Type)
|
||||||
|
@ -72,7 +72,7 @@ namespace Bit.Core.Models.Domain
|
||||||
public List<Attachment> Attachments { get; set; }
|
public List<Attachment> Attachments { get; set; }
|
||||||
public List<Field> Fields { get; set; }
|
public List<Field> Fields { get; set; }
|
||||||
public List<PasswordHistory> PasswordHistory { get; set; }
|
public List<PasswordHistory> PasswordHistory { get; set; }
|
||||||
public List<string> CollectionIds { get; set; }
|
public HashSet<string> CollectionIds { get; set; }
|
||||||
|
|
||||||
public async Task<CipherView> DecryptAsync()
|
public async Task<CipherView> DecryptAsync()
|
||||||
{
|
{
|
||||||
|
@ -153,7 +153,7 @@ namespace Bit.Core.Models.Domain
|
||||||
Favorite = Favorite,
|
Favorite = Favorite,
|
||||||
RevisionDate = RevisionDate,
|
RevisionDate = RevisionDate,
|
||||||
Type = Type,
|
Type = Type,
|
||||||
CollectionIds = CollectionIds
|
CollectionIds = CollectionIds.ToList()
|
||||||
};
|
};
|
||||||
BuildDataModel(this, c, new HashSet<string>
|
BuildDataModel(this, c, new HashSet<string>
|
||||||
{
|
{
|
||||||
|
|
|
@ -41,7 +41,7 @@ namespace Bit.Core.Models.View
|
||||||
public List<AttachmentView> Attachments { get; set; }
|
public List<AttachmentView> Attachments { get; set; }
|
||||||
public List<FieldView> Fields { get; set; }
|
public List<FieldView> Fields { get; set; }
|
||||||
public List<PasswordHistoryView> PasswordHistory { get; set; }
|
public List<PasswordHistoryView> PasswordHistory { get; set; }
|
||||||
public List<string> CollectionIds { get; set; }
|
public HashSet<string> CollectionIds { get; set; }
|
||||||
public DateTime RevisionDate { get; set; }
|
public DateTime RevisionDate { get; set; }
|
||||||
|
|
||||||
|
|
||||||
|
@ -56,10 +56,9 @@ namespace Bit.Core.Models.View
|
||||||
case CipherType.SecureNote:
|
case CipherType.SecureNote:
|
||||||
return SecureNote.SubTitle;
|
return SecureNote.SubTitle;
|
||||||
case CipherType.Card:
|
case CipherType.Card:
|
||||||
// TODO
|
return Card.SubTitle;
|
||||||
// return Card.SubTitle;
|
|
||||||
case CipherType.Identity:
|
case CipherType.Identity:
|
||||||
// return Identity.SubTitle;
|
return Identity.SubTitle;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,14 +4,34 @@ namespace Bit.Core.Models.View
|
||||||
{
|
{
|
||||||
public class IdentityView : View
|
public class IdentityView : View
|
||||||
{
|
{
|
||||||
|
private string _firstName;
|
||||||
|
private string _lastName;
|
||||||
|
private string _subTitle;
|
||||||
|
|
||||||
public IdentityView() { }
|
public IdentityView() { }
|
||||||
|
|
||||||
public IdentityView(Identity i) { }
|
public IdentityView(Identity i) { }
|
||||||
|
|
||||||
public string Title { get; set; }
|
public string Title { get; set; }
|
||||||
public string FirstName { get; set; }
|
public string FirstName
|
||||||
|
{
|
||||||
|
get => _firstName;
|
||||||
|
set
|
||||||
|
{
|
||||||
|
_firstName = value;
|
||||||
|
_subTitle = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
public string MiddleName { get; set; }
|
public string MiddleName { get; set; }
|
||||||
public string LastName { get; set; }
|
public string LastName
|
||||||
|
{
|
||||||
|
get => _lastName;
|
||||||
|
set
|
||||||
|
{
|
||||||
|
_lastName = value;
|
||||||
|
_subTitle = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
public string Address1 { get; set; }
|
public string Address1 { get; set; }
|
||||||
public string Address2 { get; set; }
|
public string Address2 { get; set; }
|
||||||
public string Address3 { get; set; }
|
public string Address3 { get; set; }
|
||||||
|
@ -27,6 +47,83 @@ namespace Bit.Core.Models.View
|
||||||
public string PassportNumber { get; set; }
|
public string PassportNumber { get; set; }
|
||||||
public string LicenseNumber { get; set; }
|
public string LicenseNumber { get; set; }
|
||||||
|
|
||||||
// TODO
|
public string SubTitle
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if(_subTitle == null && (FirstName != null || LastName != null))
|
||||||
|
{
|
||||||
|
_subTitle = string.Empty;
|
||||||
|
if(FirstName != null)
|
||||||
|
{
|
||||||
|
_subTitle = FirstName;
|
||||||
|
}
|
||||||
|
if(LastName != null)
|
||||||
|
{
|
||||||
|
if(_subTitle != string.Empty)
|
||||||
|
{
|
||||||
|
_subTitle += " ";
|
||||||
|
}
|
||||||
|
_subTitle += LastName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return _subTitle;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string FullName
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if(string.IsNullOrWhiteSpace(Title) || string.IsNullOrWhiteSpace(FirstName) ||
|
||||||
|
string.IsNullOrWhiteSpace(MiddleName) || string.IsNullOrWhiteSpace(LastName))
|
||||||
|
{
|
||||||
|
var name = string.Empty;
|
||||||
|
if(string.IsNullOrWhiteSpace(Title))
|
||||||
|
{
|
||||||
|
name = string.Concat(name, Title, " ");
|
||||||
|
}
|
||||||
|
if(string.IsNullOrWhiteSpace(FirstName))
|
||||||
|
{
|
||||||
|
name = string.Concat(name, FirstName, " ");
|
||||||
|
}
|
||||||
|
if(string.IsNullOrWhiteSpace(MiddleName))
|
||||||
|
{
|
||||||
|
name = string.Concat(name, MiddleName, " ");
|
||||||
|
}
|
||||||
|
if(string.IsNullOrWhiteSpace(LastName))
|
||||||
|
{
|
||||||
|
name = string.Concat(name, LastName);
|
||||||
|
}
|
||||||
|
return name.Trim();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string FullAddress
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
var address = Address1;
|
||||||
|
if(string.IsNullOrWhiteSpace(Address2))
|
||||||
|
{
|
||||||
|
if(string.IsNullOrWhiteSpace(address))
|
||||||
|
{
|
||||||
|
address += ", ";
|
||||||
|
}
|
||||||
|
address += Address2;
|
||||||
|
}
|
||||||
|
if(string.IsNullOrWhiteSpace(Address3))
|
||||||
|
{
|
||||||
|
if(string.IsNullOrWhiteSpace(address))
|
||||||
|
{
|
||||||
|
address += ", ";
|
||||||
|
}
|
||||||
|
address += Address3;
|
||||||
|
}
|
||||||
|
return address;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,28 @@
|
||||||
using Bit.Core.Enums;
|
using Bit.Core.Enums;
|
||||||
using Bit.Core.Models.Domain;
|
using Bit.Core.Models.Domain;
|
||||||
|
using Bit.Core.Utilities;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text.RegularExpressions;
|
||||||
|
|
||||||
namespace Bit.Core.Models.View
|
namespace Bit.Core.Models.View
|
||||||
{
|
{
|
||||||
public class LoginUriView : View
|
public class LoginUriView : View
|
||||||
{
|
{
|
||||||
|
private HashSet<string> _canLaunchWhitelist = new HashSet<string>
|
||||||
|
{
|
||||||
|
"https://",
|
||||||
|
"http://",
|
||||||
|
"ssh://",
|
||||||
|
"ftp://",
|
||||||
|
"sftp://",
|
||||||
|
"irc://",
|
||||||
|
"vnc://",
|
||||||
|
"chrome://",
|
||||||
|
"iosapp://",
|
||||||
|
"androidapp://",
|
||||||
|
};
|
||||||
|
|
||||||
private string _uri;
|
private string _uri;
|
||||||
private string _domain;
|
private string _domain;
|
||||||
private string _hostname;
|
private string _hostname;
|
||||||
|
@ -29,6 +47,63 @@ namespace Bit.Core.Models.View
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
public string Domain
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if(_domain == null && Uri != null)
|
||||||
|
{
|
||||||
|
_domain = CoreHelpers.GetDomain(Uri);
|
||||||
|
if(_domain == string.Empty)
|
||||||
|
{
|
||||||
|
_domain = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return _domain;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string Hostname
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if(_hostname == null && Uri != null)
|
||||||
|
{
|
||||||
|
_hostname = CoreHelpers.GetHostname(Uri);
|
||||||
|
if(_hostname == string.Empty)
|
||||||
|
{
|
||||||
|
_hostname = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return _hostname;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string HostnameOrUri => Hostname ?? Uri;
|
||||||
|
|
||||||
|
public bool IsWebsite => Uri != null && (Uri.StartsWith("http://") || Uri.StartsWith("https://") ||
|
||||||
|
(Uri.Contains("://") && Regex.IsMatch(Uri, CoreHelpers.TldEndingRegex)));
|
||||||
|
|
||||||
|
public bool CanLaunch
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if(_canLaunch != null)
|
||||||
|
{
|
||||||
|
return _canLaunch.Value;
|
||||||
|
}
|
||||||
|
if(Uri != null && Match != UriMatchType.RegularExpression)
|
||||||
|
{
|
||||||
|
var uri = LaunchUri;
|
||||||
|
_canLaunch = _canLaunchWhitelist.Any(prefix => uri.StartsWith(prefix));
|
||||||
|
return _canLaunch.Value;
|
||||||
|
}
|
||||||
|
_canLaunch = false;
|
||||||
|
return _canLaunch.Value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public string LaunchUri => !Uri.Contains("://") && Regex.IsMatch(Uri, CoreHelpers.TldEndingRegex) ?
|
||||||
|
string.Concat("http://", Uri) : Uri;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
using Bit.Core.Models.Domain;
|
using Bit.Core.Models.Domain;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
namespace Bit.Core.Models.View
|
namespace Bit.Core.Models.View
|
||||||
{
|
{
|
||||||
|
@ -21,7 +22,8 @@ namespace Bit.Core.Models.View
|
||||||
public string Uri => HashUris ? Uris[0].Uri : null;
|
public string Uri => HashUris ? Uris[0].Uri : null;
|
||||||
public string MaskedPassword => Password != null ? "••••••••" : null;
|
public string MaskedPassword => Password != null ? "••••••••" : null;
|
||||||
public string SubTitle => Username;
|
public string SubTitle => Username;
|
||||||
// TODO: uri launch props
|
public bool CanLaunch => HashUris && Uris.Any(u => u.CanLaunch);
|
||||||
|
public string LaunchUri => HashUris ? Uris.FirstOrDefault(u => u.CanLaunch)?.LaunchUri : null;
|
||||||
public bool HashUris => (Uris?.Count ?? 0) > 0;
|
public bool HashUris => (Uris?.Count ?? 0) > 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue