Google Drive API를 사용하여 공유 링크 클립보드에 업로드하여 복사하는 편리한 도구 만들기

개시하다
현재 일하고 있는 회사는 Google Drive의 보살핌을 받았지만, 업로드는 상당히 소박하고 번거롭다.
순서대로
  • 리소스 준비
  • 적절한 장소에서 ZIP 압축
  • 브라우저에서 GoogleDrive 페이지 열기
  • 임시로 저장된 폴더 열기
  • D&D를 통해 ZIP
  • 업로드
  • 업로드가 완료되면 파일에 도메인 공유를 활성화
  • 복제 공유 링크
  • 이런 느낌...뭐, 귀찮아.
    그래서 버튼 하나로 2-7을 완성할 수 있을지 고민해 프로그램을 만들었다.
    그렇게 어려운 일은 하지 않았지만, 약간 푹 빠졌기 때문에(이후 C#에서의 사례도 드문 것 같다) 요점을 공유했다.
    만들어진 물건
    창고는 여기 있어요.
    https://github.com/ambleside138/GoogleDriveSender
    이런 느낌으로 돌아가요.
    캡처는 개인 계정으로 이동합니다.
  • 업로드할 파일/폴더를 마우스 오른쪽 버튼으로 클릭
  • 보내는 메뉴에서 응용 프로그램 선택
  • 업로드 처리가 완료되면 링크 URL이 클립보드에 복사됩니다
  • 이런 흐름.수속이 많이 줄었다!
    응용 프로그램 만들기 요점
    앱을 어떻게 불러요?
    여러 가지 방법이 있을 것 같아요.
  • 범용(=특정 애플리케이션에 종속되지 않음)
  • 위험이 낮다(=등록하지 않는다)
  • 우리는 각양각색의 방법을 연구했다.
    가볍게 두드린 후 윈도 우클릭 메뉴에서 준비한 '발송' 메뉴는 사용자 정의가 쉬우니 이것을 사용하십시오.여기서부터 프로그램을 시작할 때 오른쪽 메뉴의 대상 파일 경로가 첫 번째 인자로 전달되기 때문에 사용합니다.
    Google Drive API의 관전 포인트
    ▲ 신규 및 업데이트 시 API 구분 필요
    GoogleDrive는 파일 이름이 아닌 개별 ID를 기반으로 파일을 인식하기 때문에 같은 파일에 Create 메서드를 여러 번 사용해 업로드하면 같은 이름의 여러 파일이 드라이브에 표시됩니다.
    따라서 같은 이름의 파일이 업로드되면 업데이트 처리로 전환됩니다.Files가 이미 업로드되었는지 여부파일 이름을 List API에 전달하고 파일의 유무에 따라 결정합니다.
    ▲ 도메인 공유
    업로드된 파일을 권한 변경 요청을 보내는 느낌으로 설치하면 OK.
    ▲ 공유 링크
    Files.Create API 반환 값을 사용하여 사용할 수 있는 WebViewLink 속성입니다.
    이렇게 되면 업로드 부분의 논리는 ↓가 된다
    DriveSender.cs
    private File Upload(string filePath, DriveService service)
    {
        var fileName = System.IO.Path.GetFileName(filePath);
    
        var listRequest = service.Files.List();
        listRequest.Q = $"name = '{fileName}' and '{_Configuration.DriveDirectoryId}' in parents and trashed=false";
        listRequest.Fields = "nextPageToken, files(id, name, webViewLink) ";
    
        // アップロード済みのファイルを更新するにはAPIを切り替える必要がある
    
        var meta = new File()
        {
            Name = System.IO.Path.GetFileName(filePath),
        };
    
        using var stream = new System.IO.FileStream(filePath, System.IO.FileMode.Open);
    
        var file = listRequest.Execute().Files.FirstOrDefault();
        if(file != null)
        {
            // 更新
            var request = service.Files.Update(meta, file.Id, stream, GetMimeType(filePath));
    
            request.Fields = "id, name, webViewLink";
            request.KeepRevisionForever = false;
    
            _Logger.Info("Request Files.Update");
            var result = request.Upload();
            if(result.Status == UploadStatus.Failed)
                throw result.Exception;
    
            request.Body.WebViewLink = file.WebViewLink;
    
            return request.Body;
        }
        else
        {
            // 新規追加
            meta.MimeType = GetMimeType(filePath);
            meta.Parents = new List<string> { _Configuration.DriveDirectoryId };
    
            var request = service.Files.Create(meta, stream, GetMimeType(filePath));
            request.Fields = "id, name, webViewLink";
            request.KeepRevisionForever = false;
    
            _Logger.Info("Request Files.Create");
            var result = request.Upload();
            if (result.Status == UploadStatus.Failed)
                throw result.Exception;
    
            _Logger.Info("権限変更");
            {
                PermissionsResource.CreateRequest permissionRequest;
    
                if(string.IsNullOrEmpty(_Configuration.Domain))
                {
                    permissionRequest = service.Permissions.Create(new Permission
                    {
                        Type = "anyone",
                        Role = "reader",
                    }, request.ResponseBody.Id);
                }
                else
                {
                    permissionRequest = service.Permissions.Create(new Permission
                    {
                        Type = "domain",
                        Role = "reader",
                        Domain = _Configuration.Domain,
                    }, request.ResponseBody.Id);
                }
    
                _Logger.Info("Request Permissions.Create");
                permissionRequest.Execute();
            }
    
            return request.ResponseBody;
        }
    }
    
    끝말
    하나하나의 조작이 그리 대단한 것은 아니지만 하루에 여러 번 문지르면 쉽게 스트레스가 쌓인다.시간이 많이 걸릴 줄은 몰랐어요. (실제로 이틀쯤?)그러니까 좀 일찍 한 걸 후회하면 돼.프로그래머에게 뇌사 상태에서 템플릿 작업을 반복하는 것은 말도 안 되는 상태이기 때문에 앞으로도 더욱 효율적일 것입니다!
    참조 사이트

    좋은 웹페이지 즐겨찾기