PromucFlow_constructor/app/server/scripts/node
dependabot[bot] d73b075aa2
chore: bump follow-redirects from 1.14.3 to 1.14.7 in /app/server/scripts/node (#10413)
Bumps [follow-redirects](https://github.com/follow-redirects/follow-redirects) from 1.14.3 to 1.14.7.
- [Release notes](https://github.com/follow-redirects/follow-redirects/releases)
- [Commits](https://github.com/follow-redirects/follow-redirects/compare/v1.14.3...v1.14.7)

---
updated-dependencies:
- dependency-name: follow-redirects
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2022-01-15 03:43:12 +05:30
..
.editorconfig Add a node.js script to dump examples organization (#448) 2020-09-02 17:15:55 +05:30
acl-migration.js chore: Fixing yoda conditions in the code (#8297) 2021-10-08 22:21:24 +05:30
dump-examples-org.js Add a node.js script to dump examples organization (#448) 2020-09-02 17:15:55 +05:30
package-lock.json chore: bump follow-redirects from 1.14.3 to 1.14.7 in /app/server/scripts/node (#10413) 2022-01-15 03:43:12 +05:30
package.json chore(deps-dev): bump axios in /app/server/scripts/node (#7318) 2021-09-09 22:14:58 +05:30
README.md Add a node.js script to dump examples organization (#448) 2020-09-02 17:15:55 +05:30

ACL Migration Steps

  1. Create a super user (with email superuser_acl@appsmith.com), using the sign-up API.

  2. Add manage and read permissions for organizations, applications, pages and actions for this super user, on ALL existing documents (in corresponding collections). Once this is done, the policies field of organizations, for example, should look something like:

{
    "policies": [         
        {
            "permission" : "manage:organizations",
            "users" : [ 
                "superuser_acl@appsmith.com"
            ],
            "groups" : []
        }, 
        {
            "permission" : "read:organizations",
            "users" : [ 
                "superuser_acl@appsmith.com"
            ],
            "groups" : []
        }
    ]
}
  1. Disable emails for invite API actions.

  2. For each user, for each organization in the user's organizationIds list, hit the invite user API for that organization, using session of the super user.

  3. Remove super user from the organization policies, without disturbing other permission values.

  4. Remove super user from users collection.

Running

Assuming you have node (>=v12), use the following command to run the migration:

npm install
node acl-migration.js 'https://localhost/api/v1/' 'mongodb://localhost:27017/mobtools'

The first argument should be a running API endpoint, and the second argument should be a URI to the database that this API endpoint is running on.