EMM ها می توانند طیف وسیعی از وظایف مدیریتی معمولی را در راه حل های سازمانی خود برای Android پیاده کنند، مانند وظایف نشان داده شده در این راهنما. کد نمونه از Google Play EMM API Client Library برای Java ® استفاده می کند.
کاربران را جستجو کنید و جزئیات کاربر را دریافت کنید
بسیاری از APIهای Google Play EMM برای انجام برخی از کارهای مرتبط با کاربر، مانند نصب برنامه، دریافت حقوق و مجوز، userId
(علاوه بر enterpriseId
) نیاز دارند. برخی از تماس ها به یک شی کاربر نیاز دارند.
اگر سازمانی از حسابهای مدیریتشده Google Play استفاده میکند، شما نقشهای را بین آدرسهای ایمیل کاربر و شناسههای کاربری برای آن حسابها انجام میدهید. با حسابهای Google، از UsersListResponse
استفاده میکنید.
کاربران را جستجو کنید
این نمونه کد شناسههای کاربری مرتبط با حسابهای Google را دریافت میکند. برای سازمانهایی که از حسابهای مدیریتشده Google Play استفاده میکنند، اعمال نمیشود.
این مثال فرض می کند که شما مدل های User
و UsersListResponse
را به کد خود وارد کرده اید. برای دریافت یک حساب کاربری خاص، userId
آن را با ارسال enterpriseId
و ایمیل به UsersListResponse
دریافت کنید.
public UsersListResponse list(String enterpriseId, String email) throws IOException { return androidEnterprise .users() .list(enterpriseId, email) .execute(); }
دریافت جزئیات کاربر
هنگامی که userId
را دارید، می توانید جزئیات دیگر را بازیابی کنید. Users.Get
را ببینید.
public User get(String enterpriseId, String userId) throws IOException { return androidEnterprise .users() .get(enterpriseId, userId) .execute(); }
به کاربر اجازه دسترسی به برنامه ها را بدهید
میتوانید از APIهای Google Play EMM برای کنترل برنامههایی که کاربر میتواند از فروشگاه مدیریتشده Google Play دسترسی داشته باشد، استفاده کنید. دسترسی به یک برنامه شامل امکان جستجو، مشاهده، نصب و به روز رسانی آن است. سه سطح دسترسی مختلف وجود دارد:
- فقط برنامه های مجاز: کاربر فقط به برنامه های خاصی دسترسی دارد.
- همه برنامههای تایید شده: کاربر به تمام برنامههایی که برای شرکت تایید شدهاند دسترسی دارد.
- همه برنامهها: کاربر به همه برنامههایی که در فروشگاه Google Play در دسترس عموم هستند دسترسی دارد.
به کاربر اجازه دهید فقط به برنامه های خاص دسترسی داشته باشد
مثال زیر نحوه دسترسی کاربر به مجموعه خاصی از برنامهها را از فروشگاه مدیریتشده Google Play نشان میدهد. فرآیند شامل مراحل زیر است:
- فهرستی از
productIds
(برنامهها) که برای کاربر تأیید شدهاند (productSet) جمعآوری کنید. - مشخص کنید که کاربر فقط با تنظیم مقدار رشته
productSetBehavior
روی"whitelist"
می تواند به برنامه های موجود در لیست داده شده دسترسی داشته باشد. - فهرست
productIds
و تنظیمات رفتار را با استفاده ازsetAvailableProductSet
در مجموعه محصول موجود کاربر اعمال کنید.
public ProductSet setProductSet(String enterpriseId, String userId, List<String> productIds) throws IOException { ProductSet productSet = new ProductSet(); productSet.setProductId(productIds); productSet.setProductSetBehavior("whitelist"); return androidEnterprise .users() .setAvailableProductSet(enterpriseId, userId, productSet) .execute(); }
به کاربر اجازه دسترسی به همه برنامه های تایید شده را بدهید
مثال زیر نحوه اعطای دسترسی کاربر به هر برنامه ای را که برای شرکت از فروشگاه مدیریت شده Google Play تأیید شده است نشان می دهد. فرآیند شامل مراحل زیر است:
- مشخص کنید که کاربر می تواند با تنظیم مقدار رشته
productSetBehavior
روی"allApproved"
به همه برنامه های تایید شده برای شرکت دسترسی داشته باشد. - این تنظیم را با استفاده از
setAvailableProductSet
برای کاربر اعمال کنید.
public ProductSet setUserIncludeApprovedApps(String enterpriseId, String userId) throws IOException { ProductSet productSet = new ProductSet(); productSet.setProductSetBehavior("allApproved"); return androidEnterprise .users() .setAvailableProductSet(enterpriseId, userId, productSet) .execute(); }
توجه: هنگامی که productSetBehavior
روی "allApproved"
تنظیم شده است، نیازی به تعیین productIds
برای productSet ندارید.
به کاربر اجازه دسترسی به همه برنامه ها را بدهید
مثال زیر نشان میدهد که چگونه میتوان در فروشگاه مدیریتشده Google Play به کاربر این امکان را داد تا به هر برنامهای که در فروشگاه عمومی Google Play موجود است دسترسی داشته باشد. کاربرانی که به همه برنامهها دسترسی دارند، هنوز فقط وقتی Google Play مدیریت شده را باز میکنند، طرحبندی فروشگاه را برای شرکت خود میبینند، اما میتوانند برنامههای اضافی را از طریق جستجو پیدا کنند.
برخی از کاربران معتمد، مانند سرپرستان فناوری اطلاعات، ممکن است به این سطح دسترسی بیشتر برای آزمایش و ارزیابی برنامهها قبل از تأیید آنها برای شرکت نیاز داشته باشند. فرآیند اعطای دسترسی کاربر به همه برنامه ها شامل مراحل زیر است:
- مشخص کنید که کاربر می تواند با تنظیم مقدار رشته
productSetBehavior
روی"includeAll"
به همه برنامه های موجود در فروشگاه Google Play دسترسی داشته باشد. - این تنظیم را با استفاده از
setAvailableProductSet
برای کاربر اعمال کنید.
public ProductSet setUserIncludeAllApps(String enterpriseId, String userId) throws IOException { ProductSet productSet = new ProductSet(); productSet.setProductSetBehavior("includeAll"); return androidEnterprise .users() .setAvailableProductSet(enterpriseId, userId, productSet) .execute(); }
توجه: هنگامی که productSetBehavior
روی "includeAll"
تنظیم شده است، نیازی به تعیین productIds
برای productSet ندارید.
یک طرح فروشگاه ایجاد کنید
پس از دادن دسترسی کاربران به برنامهها، برنامهها را در خوشههایی گروهبندی کنید تا در جلوی فروشگاه مدیریتشده Google Play نمایش داده شوند.
می توانید با استفاده از API های Storelayoutpages
و Storelayoutclusters
یک طرح فروشگاه سفارشی منحصر به فرد برای هر یک از مشتریان خود ایجاد کنید. یک طرح بندی معمولی از مجموعه ای از صفحات تشکیل شده است و هر کدام می تواند شامل خوشه هایی از برنامه ها باشد. می توانید برنامه های مرتبط را در همان خوشه قرار دهید. برای جزئیات و کد نمونه ، به ایجاد طرحبندی فروشگاه سفارشی مراجعه کنید.
مجوزهای یک برنامه را دریافت کنید
برای افزودن یک برنامه به طرحبندی فروشگاه سفارشی (یا نصب بیصدا یک برنامه در دستگاه کاربر) و نمایش برنامه به طوری که کاربر بتواند آن را انتخاب کند، سرپرست باید مجوزهای آن برنامه را برای کل سازمان بپذیرد. سرپرستان میتوانند مجوزهای برنامه را بپذیرند و برنامهها را برای توزیع در کنسول مدیریتشده Google Play علامتگذاری کنند (به نمای کلی Google Play مدیریت شده مراجعه کنید).
به عنوان بهترین روش، توصیه میکنیم iframe مجوزها را در کنسول EMM خود جاسازی کنید. این بدان معناست که کاربر مجبور نیست به طور جداگانه به کنسول مدیریت شده Google Play پیمایش کند. برای دریافت URL iframe از Products.getApprovalUrl
استفاده کنید.
public String getApprovalUrl(String enterpriseId, String productId) throws IOException { return androidEnterprise .products() .generateApprovalUrl(enterpriseId, productId) .execute() .getUrl(); }
برای پذیرش این مجوزها از Products.approve
استفاده کنید.
public void approveProduct(String enterpriseId, String productId, String approvalUrl) throws IOException { ProductsApproveRequest productsApproveRequest = new ProductsApproveRequest() .setApprovalUrlInfo( new ApprovalUrlInfo().setApprovalUrl(approvalUrl)); androidEnterprise .products() .approve(enterpriseId, productId, productsApproveRequest) .execute(); }
دستگاه های یک کاربر را دریافت کنید
برای انجام اقدامات خاص دستگاه، باید دستگاه های مرتبط با یک کاربر را شناسایی کنید. این مثال با استفاده از DevicesListResponse
، فهرست دستگاهها را برای یک userID
معین برمیگرداند.
public DevicesListResponse list(String enterpriseId, String userId) throws IOException { return androidEnterprise .devices() .list(enterpriseId, userId) .execute(); }
اگر کاربر هنگام تلاش برای دسترسی به Google Play مدیریت شده برای اولین بار با شرایط خدمات ارائه شده موافقت کند، پاسخ شامل دستگاه های مدیریت نشده (دستگاه هایی با نوع مدیریت unmanagedProfile
) می شود.
وضعیت یک دستگاه را دریافت و تنظیم کنید
این وظیفه مدیریتی فقط برای سازمانهایی اعمال میشود که از حسابهای Google استفاده میکنند. برای سازمانهایی که از حسابهای مدیریتشده Google Play استفاده میکنند، اعمال نمیشود.
هنگامی که حساب Google مدیریت شده کاربر در دستگاه مدیریت شده فعال می شود، دسترسی به خدمات Google بر اساس موارد زیر فعال (یا غیرفعال می شود)
- وضعیت دستگاه
- اینکه آیا سرپرست دامنه خطمشیهای EMM را اعمال کرده است یا نه (با تنظیم سیاستهای EMM در دستگاههای Android در کنسول مدیریت Google).
اگر اجرای EMM غیرفعال باشد، وضعیت دستگاه نادیده گرفته میشود و هر زمان که حساب در دستگاه Android فعال شود به خدمات Google دسترسی پیدا میکند. اگر اجرای EMM فعال باشد اما وضعیت دستگاه فعال نباشد، کاربران نمیتوانند برنامهها را از Google Play نصب کنند، و APIهای EMM Google Play نمیتوانند برنامهها را برای آن کاربر در بیصدا روی دستگاه نصب کنند.
این مثال نشان میدهد که چگونه میتوان وضعیت یک دستگاه معین را به دست آورد (که با پاس دادن enterpriseId
، userId
و deviceId
مشخص شده است).
عملیات getState()
و setState()
فقط برای دستگاه هایی با یک managementType
of managedDevice
یا managedProfile
(در منبع Devices
) کار می کنند. دستگاههای دارای managementType
unmanagedProfile
را نمیتوان با این APIها کنترل کرد.
public DeviceState getState(String enterpriseId, String userId, String deviceId) throws IOException { return androidEnterprise .devices() .getState(enterpriseId, userId, deviceId) .execute(); }
با تنظیم رشته AccountState
روی ثابت مناسب، خدمات Google را برای حساب در یک دستگاه فعال یا غیرفعال کنید.
public DeviceState setState(String enterpriseId, String userId, String deviceId, String accountState) throws IOException { DeviceState deviceState = new DeviceState(); deviceState.setAccountState(accountState); return androidEnterprise .devices() .setState(enterpriseId, userId, deviceId, deviceState) .execute(); }
نصب یک برنامه روی دستگاه را فشار دهید
مدیران می توانند به صورت بی صدا برنامه ها را نصب کنند. تعامل کاربر مورد نیاز نیست. این مثال از Installs.Update
برای نصب بیصدا یک برنامه (شناسایی شده توسط productId
) در دستگاه (شناسایی شده توسط deviceId
) استفاده میکند.
public Install update(String enterpriseId, String userId, String deviceId, String productId) throws IOException { return androidEnterprise .installs() .update(enterpriseId, userId, deviceId, productId, new Install()) .execute(); }
اگر برنامه از قبل در دستگاه وجود داشته باشد و نسخه به روز شده آن در دسترس باشد، برنامه به نسخه جدید به روز می شود.
برنامه ها را از لیست برنامه های تایید شده جستجو و دریافت کنید
سرپرستان فهرستی از برنامههای تأییدشده را ایجاد و مدیریت میکنند که در Google Play مدیریتشده در دسترس کاربرانشان است. کاربران دستگاههای BYOD با نمایههای کاری و کاربران دستگاههای مرتبط با شرکت که کل دستگاه توسط سازمان مدیریت میشود، میتوانند برنامهها را فقط از این فهرست تأیید شده دانلود کنند.
میتوانید کنسول EMM خود را طوری سفارشی کنید که شامل یک کادر جستجو باشد تا سرپرستان بتوانند برنامهها را فقط در لیست برنامههای تأیید شده جستجو کنند. عملکرد جستجو همان پارامترهای یک عملکرد جستجوی مدیریت شده استاندارد Google Play را می پذیرد، اما فقط برنامه های موجود در لیست برنامه های تایید شده را جستجو می کند.
به عنوان مثال، اگر مدیر بخواهد برنامهای را در لیست برنامههای تأیید شده به دستگاههای شرکت خود نصب کند، میتواند از این عملکرد جستجو در کنسول EMM برای یافتن برنامه استفاده کند.
در جستجوی خود، می توانید حداکثر تعداد محصولاتی را که نتیجه شما باید حاوی آن باشد، مانند setMaxResults(10L)
مشخص کنید، فقط به اندازه ای که صفحه را پر کند. مقدار پیشفرض 100 است، که همچنین حداکثری است که میتوان یکباره برگرداند. هنگامی که نتیجه حاوی یک نشانه صفحهبندی باشد، نتایج بیشتری وجود دارد که میتوانید با ارسال نشانه صفحهبندی آنها را بازیابی کنید.
این مثال نشان می دهد که چگونه می توان 10 نتیجه اول جستجوی برنامه های بهره وری را دریافت کرد. Products.List
را ببینید.
public ListsearchProducts(String enterpriseId) throws IOException { ProductsListResponse executeResult = androidEnterprise .products() .list(enterpriseId) .setMaxResults(10L) .setQuery("productivity") .execute(); return executeResult.getProduct(); }
اگر نتیجه جستجو حاوی نشانه صفحه بندی باشد، جستجو بیش از نتایج setMaxResults
یا بیش از 10 در این مثال تولید می کند. برای بازیابی نتایج بیشتر، جستجو را دوباره انجام دهید و نشانه صفحهبندی را در درخواست اضافه کنید. این مثال 10 نتیجه بعدی را دریافت می کند.
public ProductsListResponse continueSearch( String enterpriseId, ProductsListResponse previousResponse) throws IOException { ProductsListResponse nextResults = androidEnterprise .products() .list(enterpriseId) .setMaxResults(10L) .setToken(previousResponse.getTokenPagination().getNextPageToken()) .setQuery("productivity") .execute(); return nextResults; }