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

[JSON-API] Docs for user management endpoints #12432

Merged
merged 10 commits into from
Jan 31, 2022
Merged

Conversation

realvictorprm
Copy link
Contributor

@realvictorprm realvictorprm commented Jan 17, 2022

changelog_begin
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.

@realvictorprm realvictorprm marked this pull request as draft January 17, 2022 12:55
@realvictorprm realvictorprm force-pushed the http-json/even-more-user-endpoints branch from c44e7a2 to 77cbe9a Compare January 18, 2022 15:37
@realvictorprm realvictorprm marked this pull request as ready for review January 18, 2022 17:03
Copy link
Contributor

@stefanobaghino-da stefanobaghino-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, asking @S11001001 for approval.

docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
realvictorprm and others added 6 commits January 19, 2022 15:47
Co-authored-by: Gary Verhaegen <gary.verhaegen@digitalasset.com>
Co-authored-by: Gary Verhaegen <gary.verhaegen@digitalasset.com>
Co-authored-by: Stefano Baghino <43749967+stefanobaghino-da@users.noreply.github.com>
@realvictorprm realvictorprm changed the base branch from http-json/even-more-user-endpoints to main January 19, 2022 14:48
@realvictorprm
Copy link
Contributor Author

Sorry for the mess 🤦 Hoped github would automatically change the base but yeah :|

changelog_begin

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

changelog_end
Copy link
Contributor

@meiersi-da meiersi-da left a comment

Choose a reason for hiding this comment

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

Thanks @realvictorprm . Looks good!

There are some API design questions that would be good to resolve. Feel free to ping for a chat.


Please refer to :ref:`CreateUserRequest <com.daml.ledger.api.v1.admin.user_management_service.CreateUserRequest>` documentation for information about the meaning of the fields.

All fields in the request are required, this means that an empty JSON object is not a valid request to allocate a new user.
Copy link
Contributor

Choose a reason for hiding this comment

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

Why are primaryParty and rights required? They do have sensible defaults: empty string and empty array

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Made optional in this PR.

Creating a New User
********************

This endpoint exposes the Ledger API's :ref:`CreateUserRequest <com.daml.ledger.api.v1.admin.user_management_service.CreateUserRequest>`.
Copy link
Contributor

Choose a reason for hiding this comment

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

Suggested change
This endpoint exposes the Ledger API's :ref:`CreateUserRequest <com.daml.ledger.api.v1.admin.user_management_service.CreateUserRequest>`.
This endpoint exposes the Ledger API's :ref:`CreateUser RPC <com.daml.ledger.api.v1.admin.user_management_service.CreateUserRequest>`.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Can you elaborate on that and whether it should be done for every reference?

docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
docs/source/json-api/index.rst Outdated Show resolved Hide resolved
realvictorprm and others added 2 commits January 25, 2022 11:04
Copy link
Contributor

@meiersi-da meiersi-da left a comment

Choose a reason for hiding this comment

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

Thanks @victormueller-da for editing these docs into a uniform shape 👍

(Comment only, as I'm not the owner of these docs. I'd expect @stefanobaghino-da or @stephencompall-DA to give the final approval.)

@stefanobaghino-da
Copy link
Contributor

Thanks @victormueller-da for editing these docs into a uniform shape +1

(Comment only, as I'm not the owner of these docs. I'd expect @stefanobaghino-da or @stephencompall-DA to give the final approval.)

I dismissed your block based on your comment, if you think this should be blocked please add a further review.

@meiersi-da
Copy link
Contributor

I dismissed your block based on your comment, if you think this should be blocked please add a further review.

Oh apologies. I've overlooked that there was an open block. Thanks for taking care of it @stefanobaghino-da .

@stefanobaghino-da
Copy link
Contributor

@realvictorprm please address the outstanding build issues and merge this.

@realvictorprm
Copy link
Contributor Author

@realvictorprm please address the outstanding build issues and merge this.

Waiting for #12578 to be merged first because otherwise the docs wouldn't be correct.

@realvictorprm realvictorprm merged commit 100c59f into main Jan 31, 2022
@realvictorprm realvictorprm deleted the http-json/docs branch January 31, 2022 17:05
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
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.

5 participants