added uuid to list identities response

see #703
This commit is contained in:
Bernhard B
2025-05-26 21:56:28 +02:00
parent cb12e627fa
commit 59207541c1

View File

@@ -122,6 +122,7 @@ type IdentityEntry struct {
Fingerprint string `json:"fingerprint"`
Added string `json:"added"`
SafetyNumber string `json:"safety_number"`
Uuid string `json:"uuid"`
}
type SignalCliGroupMember struct {
@@ -1561,13 +1562,23 @@ func (s *SignalClient) UpdateProfile(number string, profileName string, base64Av
}
func (s *SignalClient) ListIdentities(number string) (*[]IdentityEntry, error) {
var err error
var rawData string
identityEntries := []IdentityEntry{}
if s.signalCliMode == JsonRpc {
jsonRpc2Client, err := s.getJsonRpc2Client()
if err != nil {
return nil, err
}
rawData, err := jsonRpc2Client.getRaw("listIdentities", &number, nil)
rawData, err = jsonRpc2Client.getRaw("listIdentities", &number, nil)
} else {
rawData, err = s.cliClient.Execute(true, []string{"--config", s.signalCliConfig, "-o", "json", "-a", number, "listIdentities"}, "")
}
if err != nil {
return nil, err
}
signalCliIdentityEntries := []SignalCliIdentityEntry{}
err = json.Unmarshal([]byte(rawData), &signalCliIdentityEntries)
if err != nil {
@@ -1580,29 +1591,10 @@ func (s *SignalClient) ListIdentities(number string) (*[]IdentityEntry, error) {
Added: strconv.FormatInt(signalCliIdentityEntry.AddedTimestamp, 10),
Fingerprint: signalCliIdentityEntry.Fingerprint,
SafetyNumber: signalCliIdentityEntry.SafetyNumber,
Uuid: signalCliIdentityEntry.Uuid,
}
identityEntries = append(identityEntries, identityEntry)
}
} else {
rawData, err := s.cliClient.Execute(true, []string{"--config", s.signalCliConfig, "-a", number, "listIdentities"}, "")
if err != nil {
return nil, err
}
keyValuePairs := parseWhitespaceDelimitedKeyValueStringList(rawData, []string{"NumberAndTrustStatus", "Added", "Fingerprint", "Safety Number"})
for _, keyValuePair := range keyValuePairs {
numberAndTrustStatus := keyValuePair["NumberAndTrustStatus"]
numberAndTrustStatusSplitted := strings.Split(numberAndTrustStatus, ":")
identityEntry := IdentityEntry{Number: strings.Trim(numberAndTrustStatusSplitted[0], " "),
Status: strings.Trim(numberAndTrustStatusSplitted[1], " "),
Added: keyValuePair["Added"],
Fingerprint: strings.Trim(keyValuePair["Fingerprint"], " "),
SafetyNumber: strings.Trim(keyValuePair["Safety Number"], " "),
}
identityEntries = append(identityEntries, identityEntry)
}
}
return &identityEntries, nil
}