GlideSysAttachment - 범위 지정됨

  • 릴리스 버전: Yokohama
  • 업데이트 날짜 2025년 01월 30일
  • 읽기13분
  • GlideSysAttachment API는 첨부 파일을 처리하는 메서드를 제공합니다.

    내용은 getContent() 가 호출될 때 바이트 배열이 아닌 문자열로 반환됩니다.

    getContentStream()이 호출되면 컨텐츠가 GlideScriptableInputStream 객체로 반환됩니다. GlideScriptableInputStream에는 문자열로 변환되지 않은 실제 바이트가 포함됩니다.

    범위가 지정된 GlideSysAttachment - GlideSysAttachment()

    GlideSysAttachment 클래스의 인스턴스를 작성합니다.

    표 1. 매개변수
    이름 유형 설명
    안 함

    범위가 지정된 GlideSysAttachment - copy(String sourceTable, String sourceID, String targetTable, String targetID)

    첨부 파일을 소스 기록에서 대상 기록으로 복사합니다.

    표 2. 매개변수
    이름 유형 설명
    sourceTable 문자열 복사할 첨부 파일이 있는 테이블의 이름입니다.
    소스 ID 문자열 소스 테이블의 sys_id.
    targetTable 문자열 첨부 파일을 추가할 테이블의 이름입니다.
    targetID 문자열 대상 테이블의 sys_id.
    표 3. 반환
    유형 설명
    문자열 복사된 첨부 파일 sys_ids의 배열입니다.
    var attachment = new GlideSysAttachment();
    var incidentSysID = 'ab1b30031b04ec101363ff37dc4bcbfc';
    var incGR = new GlideRecord('incident');
    incGR.get(incidentSysID);
    
    var copiedAttachments = attachment.copy('incident', incidentSysID, 'problem', incGR.getValue('problem_id'));
    gs.info('Copied attachments: ' + copiedAttachments);

    출력:

    Copied attachments: 6e4621df1bc420501363ff37dc4bcbb0,a87769531b0820501363ff37dc4bcba2

    범위가 지정된 GlideSysAttachment - deleteAttachment(String attachmentID)

    지정된 첨부 파일을 삭제합니다.

    표 4. 매개변수
    이름 유형 설명
    첨부 파일 ID 문자열 첨부 파일의 sys_id
    표 5. 반환
    유형 설명
    void
    var attachment = new GlideSysAttachment();
    var attachmentSysID = 'a87769531b0820501363ff37dc4bcba2';
    attachment.deleteAttachment(attachmentSysID);

    범위가 지정된 GlideSysAttachment - getAttachments(String tableName, String sys_id)

    이름, 유형 또는 크기와 같은 일치하는 첨부 파일 메타데이터가 포함된 GlideRecord를 반환합니다.

    표 6. 매개변수
    이름 유형 설명
    tableName 문자열 첨부 파일이 속한 테이블의 이름입니다. 인시던트를 예로 들 수 있습니다.
    sys_id 문자열 첨부 파일이 속한 기록의 Sys_id입니다.
    표 7. 반환
    유형 설명
    GlideRecord 이름, 유형 또는 크기 등 일치하는 첨부 파일 메타데이터를 포함하는 GlideRecord 객체입니다.

    다음 스크립트는 두 개의 첨부 파일이 있는 기록의 첨부 파일 이름을 나열합니다.

    var attachment = new GlideSysAttachment();
    
    var agr = attachment.getAttachments('<table_name>', '<record_sys_id>');
    
    while(agr.next())
    gs.info(agr.getValue('file_name'));

    출력:

    *** Script: filename1.txt
    *** Script: filename2.txt

    범위가 지정된 GlideSysAttachment - getContent(GlideRecord sysAttachment)

    첨부 파일 컨텐츠를 문자열로 반환합니다.

    이 메서드는 범위가 지정된 애플리케이션에서만 사용됩니다. 이 메서드는 전역 범위에서 사용될 때 undefined 를 반환합니다. 전역 범위에서 첨부 파일 컨텐츠를 읽으려면 GlideSysAttachment - 전역 API의 getContentStream() 메서드를 사용하십시오.
    이 방법은 첨부 파일에 대해 다음 파일 형식을 지원합니다.
    • CSV(*.csv)
    • JSON(*.json)
    • 텍스트(*.txt)
    표 8. 매개변수
    이름 유형 설명
    sysAttachment GlideRecord 첨부 파일 기록입니다.
    표 9. 반환
    유형 설명
    문자열 첨부 파일 컨텐츠를 문자열로 표시합니다. 최대 5MB의 데이터를 반환합니다.
    var attachment = new GlideSysAttachment();
    
    var agr = attachment.getAttachments('incident', '78271e1347c12200e0ef563dbb9a7109'); //create attachment GlideRecord
    
    while(agr.next()) { //for each attachment on the incident record
       gs.info(agr.getValue('file_name')); //print file name of attachment
       var attachmentContent = attachment.getContent(agr);
       gs.info('Attachment content: ' + attachmentContent); //print attachment content
    }

    출력:

    Doc1.txt
    Attachment content: I am text in a txt file attached to a record.

    범위가 지정된 GlideSysAttachment - getContentBase64(GlideRecord sysAttachment)

    첨부 파일 컨텐츠를 base64 인코딩을 사용하는 문자열로 반환합니다.

    이 메서드는 범위가 지정된 애플리케이션에서만 사용됩니다. 이 메서드는 전역 범위에서 사용될 때 undefined 를 반환합니다. 전역 범위에서 첨부 파일 컨텐츠를 읽으려면 GlideSysAttachment - 전역 API에서 getContentStream 메서드를 사용합니다.

    표 10. 매개변수
    이름 유형 설명
    sysAttachment GlideRecord 첨부 파일 기록입니다.
    표 11. 반환
    유형 설명
    문자열 첨부 파일 컨텐츠를 base64 인코딩을 사용하여 문자열로 제공합니다. 최대 5MB의 데이터를 반환합니다.
    var attachment = new GlideSysAttachment();
    
    var agr = attachment.getAttachments('incident', '78271e1347c12200e0ef563dbb9a7109'); //create attachment GlideRecord
    
    while(agr.next()) { //for each attachment on the incident record
       gs.info(agr.getValue('file_name')); //print file name of attachment
       var attachmentContent = attachment.getContentBase64(agr);
       gs.info('Attachment content: ' + attachmentContent); //print attachment content
    }

    출력:

    Doc1.txt
    Attachment content: SSBhbSB0ZXh0IGluIGEgdHh0IGZpbGUgYXR0YWNoZWQgdG8gYSByZWNvcmQuIA0=

    범위가 지정된 GlideSysAttachment - getContentStream(String sysID)

    첨부 파일 sys_id이 지정된 GlideScriptableInputStream 객체를 반환합니다.

    GlideTextReader API를 사용하여 콘텐츠 스트림을 읽을 수 있습니다.

    표 12. 매개변수
    이름 유형 설명
    sysID 문자열 첨부 파일 sys_id.
    표 13. 반환
    유형 설명
    GlideScriptableInputStream 첨부 파일 콘텐츠를 포함하는 스트림입니다.
    var attachment = new GlideSysAttachment();
    var attachmentSysID = '6e4621df1bc420501363ff37dc4bcbb0';
    var attachmentContentStream = attachment.getContentStream(attachmentSysID);
    gs.info('Attachment content stream: ' + attachmentContentStream);

    출력:

    Attachment content stream: com.glide.communications.GlideScriptableInputStream@14bd299

    범위가 지정된 GlideSysAttachment - write(GlideRecord record, String fileName, String contentType, String content)

    지정된 첨부 파일을 지정된 기록에 첨부합니다.

    표 14. 매개변수
    이름 유형 설명
    기록 GlideRecord 첨부 파일을 첨부할 기록입니다.
    fileName 문자열 첨부 파일 이름입니다.
    contentType 문자열 첨부 파일의 MIME 유형입니다(예: image/png). 콘텐츠 유형 필드의 첨부 파일 [sys_attachment] 테이블에 있습니다.
    컨텐츠 문자열 첨부 파일 컨텐츠.
    표 15. 반환
    유형 설명
    문자열 첨부 파일 sys_id. 첨부 파일이 추가되지 않은 경우 null을 반환합니다.
    var attachment = new GlideSysAttachment();
    
    //set up inputs
    var rec = new GlideRecord('incident');
    rec.get('78271e1347c12200e0ef563dbb9a7109');
    var fileName = 'example.txt';
    var contentType = 'text/csv';
    var content = 'The text that is stored inside my file';
    
    var agr = attachment.write(rec, fileName, contentType, content);
    
    gs.info('The attachment sys_id is: ' + agr);

    출력:

    The attachment sys_id is: 01271e4317c13311e0ef563dbb9abe34

    범위가 지정된 GlideSysAttachment - writeBase64(GlideRecord now_GR, String fileName, String contentType, String content_base64Encoded)

    base64 인코딩 컨텐츠를 사용하여 지정된 기록에 대한 첨부 파일을 삽입합니다.

    표 16. 매개변수
    이름 유형 설명
    now_GR GlideRecord 첨부 파일을 첨부할 기록입니다.
    fileName 문자열 첨부 파일 이름입니다.
    contentType 문자열 첨부 파일의 MIME 유형입니다(예: image/png). 콘텐츠 유형 필드의 첨부 파일 [sys_attachment] 테이블에 있습니다.
    컨텐츠 문자열 base64 형식의 첨부 파일 컨텐츠입니다.
    표 17. 반환
    유형 설명
    문자열 작성된 첨부 파일의 Sys_id입니다.
    var attachment = new GlideSysAttachment();
    
    var rec = new GlideRecord('incident');
    var incidentSysID = 'ab1b30031b04ec101363ff37dc4bcbfc';
    rec.get(incidentSysID);
    var fileName = 'example.txt';
    var contentType = 'text/csv';
    var base64Encodedcontent = 'SSBhbSB0ZXh0Lg==';
    
    var agr = attachment.writeBase64(rec, fileName, contentType, base64Encodedcontent);
    
    gs.info('The attachment sys_id is: ' + agr);

    출력:

    The attachment sys_id is: 10cde9971b0820501363ff37dc4bcba6

    범위가 지정된 GlideSysAttachment - writeContentStream(GlideRecord now_GR, String fileName, String contentType, GlideScriptableInputStream inputStream)

    입력 스트림을 사용하여 첨부 파일을 삽입합니다.

    표 18. 매개변수
    이름 유형 설명
    now_GR GlideRecord 첨부 파일을 첨부할 기록입니다.
    fileName 문자열 첨부 파일 이름입니다.
    contentType 문자열 첨부 파일의 MIME 유형입니다(예: image/png). 콘텐츠 유형 필드의 첨부 파일 [sys_attachment] 테이블에 있습니다.
    컨텐츠 GlideScriptableInputStream 첨부 파일 컨텐츠.
    표 19. 반환
    유형 설명
    문자열 작성된 첨부 파일의 Sys_id입니다.

    sys_attachment 테이블의 컨텐츠 스트림을 test_table 기록에 첨부합니다.

    function copyAttachmentToGlideRecord(conceptSysId) {
    
      // Get record from test_table using sys_id
      var targetGlideRecord = new GlideRecord("test_table");
      if (!targetGlideRecord.get(conceptSysId)) {
         throw ("Cannot find record created by test with sys_id: " + conceptSysId);
      }
    
      // Get record from sys_attachment table
      var sourceAttachmentGlideRecord = new GlideRecord('sys_attachment');    
      sourceAttachmentGlideRecord.query();
      sourceAttachmentGlideRecord.next();
    
      // Get field values from retrieved sys_attachment record
      var fileName = sourceAttachmentGlideRecord.getValue('file_name');
      var contentType = sourceAttachmentGlideRecord.getValue('content_type');
      var sourceAttachmentSysId = sourceAttachmentGlideRecord.getValue('sys_id');
    
      // Attach sys_attachment record content stream to test_table record
      var gsa = new GlideSysAttachment();
      gsa.writeContentStream(
        targetGlideRecord,
        fileName,
        contentType,
        gsa.getContentStream(sourceAttachmentSysId));
      gs.info("Attachment created");
    }