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

user react hook #12622

Merged
1 commit merged into from
Jan 27, 2022
Merged

user react hook #12622

1 commit merged into from
Jan 27, 2022

Conversation

ghost
Copy link

@ghost ghost commented Jan 27, 2022

We add a useUser hook to daml-react returning the user currently
logged in the ledger participant. create-daml-app is changed
accordingly.

CHANGELOG_BEGIN
[daml-react] A useUser react hook is added to the daml-react
TypeScript library. It allows for easy access to the currently logged in
user of a ledger participant node for ledgers supporting user
management.
CHANGELOG_END

Pull Request Checklist

  • Read and understand the contribution guidelines
  • Include appropriate tests
  • Set a descriptive title and thorough description
  • Add a reference to the issue this PR will solve, if appropriate
  • Include changelog additions in one or more commit message bodies between the CHANGELOG_BEGIN and CHANGELOG_END tags
  • Normal production system change, include purpose of change in description
  • If you mean to change the status of a component, please make sure you keep the Component Status page up to date.

NOTE: CI is not automatically run on non-members pull-requests for security
reasons. The reviewer will have to comment with /AzurePipelines run to
trigger the build.

@ghost ghost force-pushed the user_react_hook branch 2 times, most recently from 207b2bc to 8c3304e Compare January 27, 2022 13:26
@ghost ghost marked this pull request as ready for review January 27, 2022 14:16
@@ -20,6 +20,7 @@ const App: React.FC = () => {
? <DamlLedger
token={credentials.token}
party={credentials.party}
user={credentials.user}
Copy link
Contributor

Choose a reason for hiding this comment

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

This is technically a breaking change. How comfortable are we with this kind of breakage in a major release?

Copy link
Author

Choose a reason for hiding this comment

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

The user field is now optional, so it shouldn't be breaking anymore.

Copy link
Contributor

@garyverhaegen-da garyverhaegen-da left a comment

Choose a reason for hiding this comment

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

LGTM except for the fact that there's a breaking change to the public @daml/react API, so this should definitely have a changelog entry, and ideally be validated by product.

@ghost
Copy link
Author

ghost commented Jan 27, 2022

I'll add the changelog entry.

@@ -24,6 +25,7 @@ export type LedgerProps = {
token: string;
httpBaseUrl?: string;
wsBaseUrl?: string;
user: User;
Copy link
Contributor

Choose a reason for hiding this comment

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

Does this mean I can no longer use @daml/react against a ledger without user management? If so, I think this is unfortunately not an option for 2.0

Copy link
Author

@ghost ghost Jan 27, 2022

Choose a reason for hiding this comment

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

You don't require user management from the ledger, but you would have to fill this value in the UI from the received credentials in some way. The other option would be to make the value optional.

Copy link
Contributor

Choose a reason for hiding this comment

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

How about we make this optional and make useUser fail if you don’t set it?

Copy link
Author

Choose a reason for hiding this comment

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

Yes, this is fine. I'll change it.

Copy link
Contributor

Choose a reason for hiding this comment

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

I think I’m confused it’s optional in DamlLedgerState but required in LedgerProps. What am I missing?

Copy link
Author

Choose a reason for hiding this comment

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

Nothing, it should be optional in both, I missed it in the latter.

@ghost ghost force-pushed the user_react_hook branch 3 times, most recently from 018bb8f to fedf483 Compare January 27, 2022 16:21
We add a `useUser` hook to daml-react returning the user currently
logged in the ledger participant. create-daml-app is changed
accordingly.

CHANGELOG_BEGIN
[daml-react] A `useUser` react hook is added to the daml-react
TypeScript library. It allows for easy access to the currently logged in
user of a ledger participant node for ledgers supporting user
management.
CHANGELOG_END
@ghost ghost force-pushed the user_react_hook branch from fedf483 to 595db4b Compare January 27, 2022 16:34
Copy link
Contributor

@cocreature cocreature left a comment

Choose a reason for hiding this comment

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

Nice thank you!

setUser(u.userId);
} ) ()}
, [ledger]);
const user = useUser();
Copy link
Contributor

Choose a reason for hiding this comment

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

How does this work in the compat mode where user management is not available?

Copy link
Contributor

Choose a reason for hiding this comment

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

nvm figured it out, we still set the user to the party name 👍

const creds: Credentials = {
party: user["https://daml.com/ledger-api"],
user: {userId: user.email ?? user.name ?? party, primaryParty: party},
Copy link
Contributor

Choose a reason for hiding this comment

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

Where does the .email thing come from? I’m not quite clear on where we used that before.

Copy link
Author

Choose a reason for hiding this comment

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

This will come from the user object Auth0 will return after successful authentication. I think whether it is set or not depends on how the user logged in, i.e. via setting up an account first or via OAuth2.

Copy link
Contributor

Choose a reason for hiding this comment

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

makes sense thanks for the explanation

@ghost ghost merged commit 0610a44 into main Jan 27, 2022
@ghost ghost deleted the user_react_hook branch January 27, 2022 18:22
azure-pipelines bot pushed a commit that referenced this pull request Feb 2, 2022
This PR has been created by a script, which is not very smart
and does not have all the context. Please do double-check that
the version prefix is correct before merging.

@adriaanm-da is in charge of this release.

Commit log:
```
5390505 Remove participant-side command deduplication [DPP-848] (#12677)
85f2690 split release (#12700)
ed1bf24 LF: Check activeness of cached contracts inside FetchInterface (#12698)
aa2494f Speedy: check contract type after checking if they are consumed (#12691)
183f936 LF: Imporve safety of the Serialization of proto message. (#12686)
b4ed15b Changed product names in the documentation (#12668)
5caaf1f Switch github urls from zip to tar.gz (#12692)
6cdda6f Metering report [DPP-817] (#12604)
716cc22 Deduplication offset period errors handled in Sandbox-on-X [DPP-872] (#12652)
e4764cc Upgrade to GHC 9.0.2 (#12300)
1238e1b Update profiling documentation to Canton sandbox (#12680)
f1c7e9e Drop `daml ledger navigator` in favor of `daml navigator` (#12669)
7731324 Drop profile-dir validation for sandbox-kv (#12671)
1fa095a match Foldable.foldl1's argument order to DA.List.foldl1's order (#12685)
06b63e9 update NOTICES file (#12688)
2ac76fd LF: Gracefully handle serialization error of Values beyond 2GB (#12638)
0494731 Adjust response type for script JSON API user mgmt requests (#12683)
7aabc49 Update OpenTelemetry from 0.16.0 to 1.1.0 [KVL-1256] (#12568)
117c920 Bump sandbox-on-x-it-tests size (#12681)
100c59f [JSON-API] Docs for user management endpoints (#12432)
92938d5 Moved com.daml.platform.sandbox to com.daml.ledger.sandbox in SoX (#12675)
8d5d3bd [JSON-API] User management endpoint adjustments (#12578)
54c427f Expose documentation for user-management functions in daml-script. (#12674)
c1afabe [participant-state] Add earliest_offset metadata to pruned data error [kvl-1270] (#12546)
ef18bf4 DEV all caps needed to exclude dev dependencies (#12679)
3d3d84f User management in daml-script over json API (#12646)
182edde [compatiblity tests] Limit the exclusion to versions that have the CommandDeduplication:Participant* tests (#12660)
f08dfa3 Bump terraform (#12670)
366cd89 Add new interface serializability tests (#12666)
84cec38 Upgrade ghc-lib (#12664)
d215a01 Enable user management for the Canton sandbox (#12667)
bb5722c Move sandbox-classic test lib and IT tests to Sandbox-on-x (#12641)
c9a65d1 update NOTICES file (#12659)
1fa7f61 ci: pin workdirs on Windows (#12645)
dcbb398 Typecheck experimental primitives in damlc (#12650)
0d5443f Drop direct dependencies on system-filepath (#12658)
49f37b8 Allow defining ledger-begin and ledger-end offset conditions in ledger-api-bench-tool [DPP-836] (#12521)
f1560ce Support `implements` qualified interfaces (#12644)
20836b1 Address CVE-2022-0355 alert, resolve `simple-get` to 4.0.1 (#12655)
49e6646 Clean up unstable-types test (#12648)
214951e Fix log string interpolation in AkkaExecutionSequencer (#12647)
c72c27c [User management] Terminate ongoing streams when user state has changed [DPP-830] (#12437)
35eae89 Compiler: expose LF builtin ExerciseByKey (#12615)
dfdb7ce Remove DA.Generics (#12634)
14f43e4 update NOTICES file (#12642)
cfa8d30 [Sandbox-on-X] Ledger-side in-memory command deduplication [DPP-872] (#12596)
7567cf5 Add scala serializability checks for interfaces (#12631)
39a421e Drop unused silencer variable (#12640)
4ec336d [User management] Enforce 1k user rights limit [DPP-833] (#12558)
16a13e2 Remove redundant conformance tests from ledger-on-sql (#12639)
0610a44 daml-react: add an useUser hook (#12622)
579fb20 Reenable Canton contract id tests (#12637)
60a0f03 Hide primitiveInterface from docs (#12635)
536e493 Bump canton to latest snapshot (#12633)
613e070 Wrap client instead of runner in script test (#12630)
d5ede55 Turn name collision warnings for virtual modules into errors (#12627)
d5ae82d Bump cached-path-relative from 1.0.2 to 1.1.0 (#12632)
f4c2862 Split release 2022-01-27 (#12624)
9e5425e update NOTICES file (#12613)
fcb6124 Simplify Nix GHC derivation (#12620)
5a47223 ledger-on-memory: Do not create iterators on a mutable log. (#12626)
d2216b3 Clean up unused test and unnecessary flags in ledger-on-sql tests (#12623)
345e267 create-daml-app: Use alias templates for display names (#12390)
2e3ae0d Disable ghcide snapshot on Windows (#12621)
e55622e Remove a bunch of ledger-on-memory tests (#12618)
f5c9a67 Remove DA.Experimental.Interfaces (#12619)
5810c25 release 2.0.0-snapshot.20220127.9042.0.4038d0a7 (#12614)
f396da5 Run ledger-api-test-tool tests on ledger-on-sql with PostgreSQL (#12616)
89ce7d0 Remove conflict-checking logic from JdbcLedgerDao [DPP-808] (#12555)
```
Changelog:
```
with experimental support for non-aggregated metering reporting
- [Daml Standard Library] An argument order in the default
  implementation of ``Foldable.foldl1`` was reversed from that of
  ``DA.List.foldl1``; this incompatibly changes the former to match the
  latter.

- [HTTP-JSON] Added documentation for the new user management endpoints

- [HTTP-JSON] Adjusted the response for the createUser & deleteUser endpoint to an empty object instead of "true". This was done to allow possible future extensions to the return type without applying breaking changes.
- [HTTP-JSON] Made the field rights optional for the request body of the createUser endpoint. Now it is possible to create a user with just the userId (i.e. { "userId": "nice.user" }).

- [Integration Kit] - ledger-api-bench-tool allow to define ledger-begin and ledger-end offset boundaries for streams.
Ledger API Specification: When using user management based authorization streams will now get aborted on authenticated user's rights change.
- [Daml Standard Library] The DA.Generics module has been removed.
Ledger API Specification: Maximum number of user rights per user is now limited to 1000 and is added to UserManagementFeature in VersionService. getLedgerApiVersion endpoint.
[daml-react] A `useUser` react hook is added to the daml-react
TypeScript library. It allows for easy access to the currently logged in
user of a ledger participant node for ledgers supporting user
management.
```

CHANGELOG_BEGIN
CHANGELOG_END
This pull request was closed.
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.

2 participants