Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace UUID with locator #237

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

aruokhai
Copy link

@aruokhai aruokhai commented Sep 4, 2023

Objective
Ensure locators are returned instead of uuid's under appointments section when user details are fetched through the cli using the getuser command.

Problem
locator is an appropriate identifier for appointments in the Bolt13 specification draft, which is also being used in the getappointments cli command , but in the getuser cli command uuid is being used which can be confusing . The solution is ensure getuser cli command makes use of locator and not uuid.

Changes

  • Modified internal.rs get_user_info function to make use of locator and not uuid when returning user appointments info.
  • Modified internal.rs get_user test to reflect the change from uuid to locator.

Scope Of Change
This is a non critical change, as it only affects the CLI.

closes #229

@sr-gi
Copy link
Member

sr-gi commented Sep 14, 2023

@aruokhai thanks for looking at this. This is going to make much more sense after merging #190, which gets rid of all in-memory data for the tower. Hence, a big refactor will be needed, but it would make the change way smaller. I'd suggest you wait until that is landed and take another look at it.

@sr-gi
Copy link
Member

sr-gi commented Sep 14, 2023

@aruokhai we just landed #190

@aruokhai
Copy link
Author

would take a look at it again and start working on a new fix

@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 2f84a27 to 1652ac6 Compare December 15, 2023 19:45
@aruokhai
Copy link
Author

added the necessary changes

Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Other than the lint issue, LGTM!

You should squash the 3 commits into one and sign it. And another commit if you decide to modify get_appointments in the PR.

teos/src/api/internal.rs Outdated Show resolved Hide resolved
Copy link
Member

@sr-gi sr-gi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh wow, I have had a review for this pending for months and I never submitted it 🤦

Disregard the old comments.

.gitignore Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch 3 times, most recently from a6d7a59 to 50e1fc9 Compare December 21, 2023 10:40
Copy link
Member

@sr-gi sr-gi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Quick check, the concept is OK but the approach is not, check comments inline

teos/proto/teos/v2/appointment.proto Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 50e1fc9 to 143b826 Compare December 21, 2023 19:44
@aruokhai aruokhai requested a review from sr-gi December 21, 2023 19:45
Copy link
Member

@sr-gi sr-gi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Better, but I think the approach can still be improved

teos/proto/teos/v2/appointment.proto Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 143b826 to d3819c0 Compare December 26, 2023 21:47
@aruokhai aruokhai requested a review from sr-gi December 26, 2023 21:48
Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Getting better. Need to filter trackers and some polishing.

teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/cli.rs Outdated Show resolved Hide resolved
teos/src/main.rs Outdated Show resolved Hide resolved
Copy link
Member

@sr-gi sr-gi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some additional comments on top of @mariocynicys's, looking better overall

teos/build.rs Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/cli.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/main.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from d3819c0 to 332f3c4 Compare January 8, 2024 18:29
@aruokhai aruokhai requested a review from sr-gi January 8, 2024 18:31
@mariocynicys mariocynicys self-assigned this Feb 26, 2024
Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Awesome! Looking very good!

Needs some bigger/more generic tests though.

teos/src/cli.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 332f3c4 to 152020f Compare March 7, 2024 09:14
@aruokhai aruokhai requested a review from mariocynicys March 11, 2024 05:53
Copy link
Member

@sr-gi sr-gi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks pretty good. I left mostly rustlang improvements and some comments/nits.

The main things missing are more tests for get_appointment, this should be close to mergeable at this point

teos/src/watcher.rs Outdated Show resolved Hide resolved
teos/src/watcher.rs Outdated Show resolved Hide resolved
teos/proto/teos/v2/appointment.proto Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/cli.rs Show resolved Hide resolved
aruokhai added 2 commits April 4, 2024 14:51
modified test to reflect change

modified Todo to reflect recent change

Signed-off-by: aruokhai <[email protected]>
Signed-off-by: aruokhai <[email protected]>

removed todo

Signed-off-by: aruokhai <[email protected]>

added broader unit test
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 4ce7c8e to 4f2d7a8 Compare April 4, 2024 13:52
@aruokhai aruokhai requested a review from sr-gi April 4, 2024 13:57
Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! I think this is @ final stages.
Left some suggestions/refactors inline.

Comment on lines +342 to 349
if locator_and_userid.is_some() {
sql.push_str(" AND a.locator=(?1)");
}

// If a user_id is passed, filter even more.
if locator_and_userid.is_some_and(|inner| inner.1.is_some()) {
sql.push_str(" AND a.user_id=(?2)");
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
if locator_and_userid.is_some() {
sql.push_str(" AND a.locator=(?1)");
}
// If a user_id is passed, filter even more.
if locator_and_userid.is_some_and(|inner| inner.1.is_some()) {
sql.push_str(" AND a.user_id=(?2)");
}
if let Some((locator, optional_userid)) = locator_and_userid {
sql.push_str(" AND a.locator=(?1)");
query_args.push(locator.to_vec());
if let Some(user_id) = optional_userid {
sql.push_str(" AND a.user_id=(?2)");
query_args.push(user_id.to_vec());
}
}

Copy link
Author

@aruokhai aruokhai May 28, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this statement let mut stmt = self.connection.prepare(&sql).unwrap(); would prevent the addition of query_args.push(locator.to_vec()); . I believe only after the initialisation of the stmt variable can be query args be added , which also takes arrays as its parameters. Also the intial changes was made this way, in which i mean joined

if let Some((_, user_id)) = locator_and_userid {
            sql.push_str(" AND a.locator=(?1)");
            if user_id.is_some() {
                sql.push_str(" AND a.user_id=(?2)");
            }
        };

in which Sergio recommended i split to make it cleaner.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yup, this actually wouldn't work since stmt.query(...) won't accept a rust vector. I found this extension which allows preparing a statement with vector as args, but it's not worth the hustle. I only suggested this to not use the match below but it's not bad anyway.

Regarding nested checks, splitting the checks up in different lines makes sense when the method's args are Option<Locator> and Option<UserId>, because then we would add the appropriate filters without thinking about the dependency between them (we shouldn't nest the checks in this case).

But we went with the Option<(Locator, Option<UserId>)> route, in which there is a dependency between the locator and the user id (locator has to exist for user id to exist), so it makes more sense have the check for user id nested inside.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Guess I found the review comment you are referring to. Well then, let's keep it as it is now until we all agree on how this should look.

@sr-gi What do you think about the comment above.

teos/src/dbm.rs Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/dbm.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Outdated Show resolved Hide resolved
teos/src/api/internal.rs Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 4f2d7a8 to 122deaf Compare May 28, 2024 22:33
@aruokhai aruokhai requested a review from mariocynicys May 28, 2024 22:34
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from 122deaf to e7cbc32 Compare May 28, 2024 22:37
Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks!
Only one request from my side.
Looks good otherwise.

Comment on lines +534 to +540
let user_id = get_random_user_id().to_vec();
let locator = get_random_locator().to_vec();
let response = internal_api
.get_appointments(Request::new(msgs::GetAppointmentsRequest {
locator,
user_id: Some(user_id),
}))
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yup! thanks

Comment on lines +558 to +559
let random_number = 4 * i + 7;
let appointments_to_create = random_number;
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's indeed way more readable, thanks!

teos/src/api/internal.rs Outdated Show resolved Hide resolved
@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch 2 times, most recently from 1f152b1 to be0b6f2 Compare June 29, 2024 07:08
@aruokhai aruokhai requested a review from mariocynicys June 29, 2024 07:09
Copy link
Collaborator

@mariocynicys mariocynicys left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks!
LGTM

@aruokhai aruokhai force-pushed the replace_uuid_with_locator branch from be0b6f2 to ca497ee Compare July 1, 2024 08:41
@sr-gi
Copy link
Member

sr-gi commented Sep 5, 2024

Looks like this may be mergeable (?). Planing to give it a last look and merge if so. Needs rebase now that everything is green again

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Make teos-cli get_user return locators in appointments
3 participants