获取属于特定组的工作表

时间:2016-04-19 23:35:11

标签: smartsheet-api smartsheet-c#-sdk-v2

如何判断工作表是否属于某个组?

例如,我们有一个名为RPR的组,当我们创建工作表时,我们与组织中将组应用于工作表的其他用户共享。

// Get all sheets modified within last day    
SmartSheetList = smartsheet
        .SheetResources
        .ListSheets(new SheetInclusion[] { SheetInclusion.OWNER_INFO }, new PaginationParameters(true, null, null))
        .Data
        .Where(d => d.ModifiedAt.Value.Date >= DateTime.Now.AddDays(-1).Date)
        .ToList();

// Get organization sheets
var orgUserSheets = smartsheet.UserResources.SheetResources.ListSheets(true).Data.ToList();

// get specific group
var group = smartsheet.GroupResources.ListGroups(null).Data.Where(grp => grp.Id == some-id-here).First();

使用上面的代码,我可以看到一张工作表是否属于某个组织,但我无法判断该工作表是否属于某个组。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:1)

每张工作表还需要一个API请求才能检索工作表上的共享列表。请记住,工作表可以直接在工作表上或通过工作区共享。

要获取直接或通过工作区与特定组共享的工作表,您可以使用类似下面的代码(依赖于此示例的LINQ)。

SmartsheetClient cl = new SmartsheetBuilder()
    .SetAccessToken(ACCESS_TOKEN)
    .Build();

var includeAll = new PaginationParameters(true, null, null);
Console.WriteLine("Looking for group " + SOUGHT_GROUP_NAME);
var groups = cl.GroupResources.ListGroups(includeAll);
var soughtGroup = groups.Data.Single((group) => group.Name == SOUGHT_GROUP_NAME);
Console.WriteLine("Found group ID {0} for group {1}.", soughtGroup != null ? soughtGroup.Id.ToString() : "NULL", SOUGHT_GROUP_NAME);
if (soughtGroup == null)
    throw new ArgumentException("Group not found");

var sheets = cl.SheetResources.ListSheets(null, includeAll);
Console.WriteLine("Querying through {0} sheets...", sheets.Data.Count);
var sheetsSharedWithGroup = from sheet in sheets.Data
                            from share in cl.SheetResources.ShareResources.ListShares(sheet.Id.Value, includeAll, ShareScope.Workspace).Data
                            where share.GroupId == soughtGroup.Id
                            select new { Sheet = sheet, Share = share };

var found = sheetsSharedWithGroup.ToList();
Console.WriteLine("Found {0} sheets shared with group {1}.", found.Count, SOUGHT_GROUP_NAME);
found.ForEach(foundSheet => Console.WriteLine("Sheet {0} shared with {1} ({2})", foundSheet.Sheet.Name, foundSheet.Share.Name, foundSheet.Share.Type));

注意:我提交了a pull request以添加对特定ListShares重载的支持,该重载也返回工作空间共享。这可以在REST API中使用,但尚未在C#SDK中使用。

注意:上述代码尚未考虑Smartsheet Sights。应该可以使用相应的景点REST API(即List SightsList Sight Shares,但我认为它还不在C#SDK中。

相关问题