googleapis
Version:
Google APIs Client Library for Node.js
296 lines (295 loc) • 9.25 kB
TypeScript
/**
* Copyright 2015 Google Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { AxiosPromise } from 'axios';
import { GoogleApis } from '../..';
import { BodyResponseCallback, GlobalOptions, MethodOptions } from '../../lib/api';
/**
* G Suite Activity API
*
* Provides a historical view of activity.
*
* @example
* const google = require('googleapis');
* const appsactivity = google.appsactivity('v1');
*
* @namespace appsactivity
* @type {Function}
* @version v1
* @variation v1
* @param {object=} options Options for Appsactivity
*/
export declare class Appsactivity {
_options: GlobalOptions;
google: GoogleApis;
root: this;
activities: Resource$Activities;
constructor(options: GlobalOptions, google: GoogleApis);
getRoot(): this;
}
/**
* An Activity resource is a combined view of multiple events. An activity has a
* list of individual events and a combined view of the common fields among all
* events.
*/
export interface Schema$Activity {
/**
* The fields common to all of the singleEvents that make up the Activity.
*/
combinedEvent: Schema$Event;
/**
* A list of all the Events that make up the Activity.
*/
singleEvents: Schema$Event[];
}
/**
* Represents the changes associated with an action taken by a user.
*/
export interface Schema$Event {
/**
* Additional event types. Some events may have multiple types when multiple
* actions are part of a single event. For example, creating a document,
* renaming it, and sharing it may be part of a single file-creation event.
*/
additionalEventTypes: string[];
/**
* The time at which the event occurred formatted as Unix time in
* milliseconds.
*/
eventTimeMillis: string;
/**
* Whether this event is caused by a user being deleted.
*/
fromUserDeletion: boolean;
/**
* Extra information for move type events, such as changes in an object's
* parents.
*/
move: Schema$Move;
/**
* Extra information for permissionChange type events, such as the user or
* group the new permission applies to.
*/
permissionChanges: Schema$PermissionChange[];
/**
* The main type of event that occurred.
*/
primaryEventType: string;
/**
* Extra information for rename type events, such as the old and new names.
*/
rename: Schema$Rename;
/**
* Information specific to the Target object modified by the event.
*/
target: Schema$Target;
/**
* Represents the user responsible for the event.
*/
user: Schema$User;
}
/**
* The response from the list request. Contains a list of activities and a token
* to retrieve the next page of results.
*/
export interface Schema$ListActivitiesResponse {
/**
* List of activities.
*/
activities: Schema$Activity[];
/**
* Token for the next page of results.
*/
nextPageToken: string;
}
/**
* Contains information about changes in an object's parents as a result of
* a move type event.
*/
export interface Schema$Move {
/**
* The added parent(s).
*/
addedParents: Schema$Parent[];
/**
* The removed parent(s).
*/
removedParents: Schema$Parent[];
}
/**
* Contains information about a parent object. For example, a folder in Drive is
* a parent for all files within it.
*/
export interface Schema$Parent {
/**
* The parent's ID.
*/
id: string;
/**
* Whether this is the root folder.
*/
isRoot: boolean;
/**
* The parent's title.
*/
title: string;
}
/**
* Contains information about the permissions and type of access allowed with
* regards to a Google Drive object. This is a subset of the fields contained in
* a corresponding Drive Permissions object.
*/
export interface Schema$Permission {
/**
* The name of the user or group the permission applies to.
*/
name: string;
/**
* The ID for this permission. Corresponds to the Drive API's permission
* ID returned as part of the Drive Permissions resource.
*/
permissionId: string;
/**
* Indicates the Google Drive permissions role. The role determines a
* user's ability to read, write, or comment on the file.
*/
role: string;
/**
* Indicates how widely permissions are granted.
*/
type: string;
/**
* The user's information if the type is USER.
*/
user: Schema$User;
/**
* Whether the permission requires a link to the file.
*/
withLink: boolean;
}
/**
* Contains information about a Drive object's permissions that changed as a
* result of a permissionChange type event.
*/
export interface Schema$PermissionChange {
/**
* Lists all Permission objects added.
*/
addedPermissions: Schema$Permission[];
/**
* Lists all Permission objects removed.
*/
removedPermissions: Schema$Permission[];
}
/**
* Photo information for a user.
*/
export interface Schema$Photo {
/**
* The URL of the photo.
*/
url: string;
}
/**
* Contains information about a renametype event.
*/
export interface Schema$Rename {
/**
* The new title.
*/
newTitle: string;
/**
* The old title.
*/
oldTitle: string;
}
/**
* Information about the object modified by the event.
*/
export interface Schema$Target {
/**
* The ID of the target. For example, in Google Drive, this is the file or
* folder ID.
*/
id: string;
/**
* The MIME type of the target.
*/
mimeType: string;
/**
* The name of the target. For example, in Google Drive, this is the title of
* the file.
*/
name: string;
}
/**
* A representation of a user.
*/
export interface Schema$User {
/**
* A boolean which indicates whether the specified User was deleted. If true,
* name, photo and permission_id will be omitted.
*/
isDeleted: boolean;
/**
* Whether the user is the authenticated user.
*/
isMe: boolean;
/**
* The displayable name of the user.
*/
name: string;
/**
* The permission ID associated with this user. Equivalent to the Drive
* API's permission ID for this user, returned as part of the Drive
* Permissions resource.
*/
permissionId: string;
/**
* The profile photo of the user. Not present if the user has no profile
* photo.
*/
photo: Schema$Photo;
}
export declare class Resource$Activities {
root: Appsactivity;
constructor(root: Appsactivity);
getRoot(): Appsactivity;
/**
* appsactivity.activities.list
* @desc Returns a list of activities visible to the current logged in user.
* Visible activities are determined by the visiblity settings of the object
* that was acted on, e.g. Drive files a user can see. An activity is a record
* of past events. Multiple events may be merged if they are similar. A
* request is scoped to activities from a given Google service using the
* source parameter.
* @alias appsactivity.activities.list
* @memberOf! ()
*
* @param {object=} params Parameters for request
* @param {string=} params.drive.ancestorId Identifies the Drive folder containing the items for which to return activities.
* @param {string=} params.drive.fileId Identifies the Drive item to return activities for.
* @param {string=} params.groupingStrategy Indicates the strategy to use when grouping singleEvents items in the associated combinedEvent object.
* @param {integer=} params.pageSize The maximum number of events to return on a page. The response includes a continuation token if there are more events.
* @param {string=} params.pageToken A token to retrieve a specific page of results.
* @param {string=} params.source The Google service from which to return activities. Possible values of source are: - drive.google.com
* @param {string=} params.userId Indicates the user to return activity for. Use the special value me to indicate the currently authenticated user.
* @param {object} [options] Optionally override request options, such as `url`, `method`, and `encoding`.
* @param {callback} callback The callback that handles the response.
* @return {object} Request object
*/
list(params?: any, options?: MethodOptions): AxiosPromise<Schema$ListActivitiesResponse>;
list(params?: any, options?: MethodOptions | BodyResponseCallback<Schema$ListActivitiesResponse>, callback?: BodyResponseCallback<Schema$ListActivitiesResponse>): void;
}