AnsweredAssumed Answered

By pass Portal web map authentication in JavaScript 3.23

Question asked by Geokishore on Apr 3, 2018
Latest reply on Apr 3, 2018 by balajiveera

Goal: Develop a web application using ArcGIS JavaScript API that has a single login experience for the end user and that enables them to edit feature layers hosted on Portal for ArcGIS.

Setup: We are using OpenText Coordys development environment. The GIS HTML Javascript application is in X-Form (Iframe) of the Coordys sytem. The web map consumed by the application from Portal for ArcGIS 10.5.1 and ArcGIS Server 10.5.1

The ArcGIS Enterprise environment is 10.5.1 (ArcGIS Server is federated and hosted) and exposed to internet using reverse proxy from organization. We are using ArcGIS JavaScript 3.23

The web map is shared only with a group and a technical user has the access to this group.

Whoever access the coordys application should be able to view the GIS map without asking authentication. The technical user is configured in Coordys to generate the token directly from portal and pas the token details to GIS map viewer with a service.

We are able to get the token before creating the map and utilized in Identity manager to register. However, while creating the map the error returned in JS and map is not creating.

The code is:





























    function (Map, Navigation, FeatureLayer, PopupTemplate, InfoTemplate, webMercatorUtils, FeatureLayer, LayerInfo, urlUtils, arcgisUtils, Field, esriConfig, GeometryService, OverviewMap, Legend, LayerList, Scalebar, HomeButton, Search, BasemapGallery, Basemap, Measurement, LocateButton, Point, SpatialReference, esriId

) {


        var tokenProp = { expires: parseInt(globalPSObj.expires), server: Configs.portalurl + "/sharing/rest", ssl: globalPSObj.ssl, token: globalPSObj.Token, userId: globalPSObj.userId };

esriId. registerToken(tokenProp);

        arcgisUtils.arcgisUrl = Configs.portalurl + "/sharing/content/items";

        arcgisUtils.createMap(Configs.webmapid, "map").then(function (response) {


            var map =;

            var ProjectRequests, Estimates, ProposedProjects, PR_Point;



Please advice the approach I am following is correct or what is the best way to implement this to by pass the user login.