JP6536308B2 - INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM - Google Patents

INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM Download PDF

Info

Publication number
JP6536308B2
JP6536308B2 JP2015181193A JP2015181193A JP6536308B2 JP 6536308 B2 JP6536308 B2 JP 6536308B2 JP 2015181193 A JP2015181193 A JP 2015181193A JP 2015181193 A JP2015181193 A JP 2015181193A JP 6536308 B2 JP6536308 B2 JP 6536308B2
Authority
JP
Japan
Prior art keywords
component
information
series
processes
request
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2015181193A
Other languages
Japanese (ja)
Other versions
JP2017058791A (en
Inventor
龍太郎 坂梨
龍太郎 坂梨
雄一郎 林
雄一郎 林
晃佑 波平
晃佑 波平
東哲 張
東哲 張
和徳 杉村
和徳 杉村
光 小南
光 小南
志 閔
志 閔
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Ricoh Co Ltd
Original Assignee
Ricoh Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Ricoh Co Ltd filed Critical Ricoh Co Ltd
Priority to JP2015181193A priority Critical patent/JP6536308B2/en
Publication of JP2017058791A publication Critical patent/JP2017058791A/en
Application granted granted Critical
Publication of JP6536308B2 publication Critical patent/JP6536308B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Description

本発明は、情報処理システム、情報処理装置、情報処理方法、及びプログラムに関する。   The present invention relates to an information processing system, an information processing apparatus, an information processing method, and a program.

近年、クラウドコンピューティング等により多種多様な外部サービスが提供されるようになった。例えば、ユーザにより指定された電子データを外部のストレージに保管する外部サービスが知られている。   In recent years, various external services have come to be provided by cloud computing and the like. For example, an external service is known that stores electronic data designated by a user in an external storage.

また、例えば、画像形成装置で原稿をスキャンして取得した画像データを外部ストレージに保管する技術が知られている(例えば特許文献1参照)。このように、画像形成装置と外部サービスとが連携して処理を行う技術が従来から知られている。   Further, for example, there is known a technology for storing image data acquired by scanning an original with an image forming apparatus in an external storage (see, for example, Patent Document 1). As described above, there is conventionally known a technology in which an image forming apparatus and an external service cooperate to perform processing.

しかしながら、上記の従来技術においては、外部サービスと連携して処理を行うためには画像形成装置に搭載されるアプリケーションの開発が必要となる。また、ある外部サービスが固有の機能(他の外部サービスが提供していない機能)を提供するようになった場合には、当該固有の機能を利用するためのモジュールやプラグイン等を開発する必要がある。したがって、画像形成装置に搭載されるアプリケーションの追加や修正等の開発に要する工数が大きくなる場合があった。   However, in the above-described prior art, in order to perform processing in cooperation with an external service, it is necessary to develop an application installed in the image forming apparatus. In addition, when an external service comes to provide a unique function (a function not provided by another external service), it is necessary to develop a module, plug-in, etc. for using the specific function. There is. Therefore, the number of man-hours required for development such as addition or correction of an application installed in the image forming apparatus may be increased.

本発明の一実施形態は、上記の点に鑑みてなされたもので、外部サービスと連携した処理を行うためのアプリケーションの開発を支援することを目的とする。   One embodiment of the present invention is made in view of the above-mentioned point, and aims at supporting development of an application for performing processing in cooperation with an external service.

上記目的を達成するため、本発明の一実施形態は、1以上の情報処理装置が含まれる情報処理システムであって、電子データを用いた一連の処理を、該一連の処理それぞれを実行するコンポーネントを組み合わせて実行するアプリケーション毎に、該アプリケーションを識別するアプリ識別情報と、前記一連の処理に関する情報と、前記一連の処理に用いる前記電子データを指定させる画面の画面情報と、を関連付けて記憶する第1の記憶手段と、前記コンポーネントに関する情報を記憶する第2の記憶手段と、前記情報処理システムに接続される1以上の機器のうちの一の機器から前記アプリ識別情報を含む第1の要求を受け付けると、該第1の要求に含まれる該アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記画面情報を、要求元の前記一の機器に送信する送信手段と、前記送信手段により送信された前記画面情報に基づき前記一の機器に表示された画面を介してユーザにより指定された電子データに関する情報を含む第2の要求を前記一の機器から受け付けると、前記アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記一連の処理に関する情報に基づく一連の処理を、前記第2の要求に含まれる前記電子データに関する情報により指定される電子データを用いて実行する処理実行手段とを有し、前記処理実行手段は、前記一連の処理に関する情報と前記コンポーネントに関する情報とに基づき生成されたコンポーネントを組み合わせて、前記電子データを用いた前記一連の処理を実行する。   In order to achieve the above object, an embodiment of the present invention is an information processing system including one or more information processing apparatuses, which is a component that executes a series of processes using electronic data, each series of processes. Application identification information for identifying the application, information on the series of processes, and screen information of a screen for specifying the electronic data used for the series of processes, in association with each other and stored. A first request that includes the application identification information from one of the first storage unit, the second storage unit that stores information related to the component, and one or more devices connected to the information processing system , The screen stored in the first storage unit in association with the application identification information included in the first request Information about the electronic data specified by the user via the screen displayed on the one device based on the transmission means for transmitting the information to the one device of the request source and the screen information transmitted by the transmission means When a second request including the request is received from the one device, a series of processes based on the information regarding the series of processes stored in the first storage unit in association with the application identification information is the second process. Processing execution means for executing using electronic data specified by the information related to the electronic data included in the request, the processing execution means generated based on the information related to the series of processing and the information related to the component Components are combined to execute the series of processes using the electronic data.

本発明の一実施形態によれば、外部サービスと連携した処理を行うためのアプリケーションの開発を支援することができる。   According to one embodiment of the present invention, development of an application for performing processing in cooperation with an external service can be supported.

第一の実施形態に係る情報処理システムの一例のシステム構成を示す図である。It is a figure showing an example system configuration of an information processing system concerning a first embodiment. 第一の実施形態に係るサービス提供システム及びPC端末の一例のハードウェア構成を示す図である。It is a figure which shows the hardware configuration of an example of the service provision system which concerns on 1st embodiment, and a PC terminal. 第一の実施形態に係る画像形成装置の一例のハードウェア構成を示す図である。FIG. 1 is a diagram illustrating a hardware configuration of an example of an image forming apparatus according to a first embodiment. 第一の実施形態に係る情報処理システムの一例の処理ブロックを示す図である。It is a figure showing the processing block of an example of the information processing system concerning a first embodiment. 共通I/F及び固有I/Fの一例を示す図である。It is a figure which shows an example of common I / F and intrinsic | native I / F. データ定義の一例を示す図である。It is a figure which shows an example of data definition. レイアウト情報の一例を示す図である。It is a figure which shows an example of layout information. 処理内容の一例を示す図である。It is a figure showing an example of processing contents. 第一の実施形態に係るスキャン配信サービスの全体処理の一例を示すシーケンス図である。It is a sequence diagram which shows an example of the whole process of the scan delivery service which concerns on 1st embodiment. スキャン配信サービスを利用するためのアプリ画面の一例を示す図である。It is a figure which shows an example of the application screen for utilizing a scan delivery service. 第一の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。It is a figure which shows the processing block of an example of the logic processing part which concerns on 1st embodiment. 第一の実施形態に係るコンポーネント情報テーブルの一例を示す図である。It is a figure which shows an example of the component information table which concerns on 1st embodiment. 型変換テーブルの一例を示す図である。It is a figure which shows an example of a type conversion table. 第一の実施形態に係るフロー実行処理の一例を示すシーケンス図である。It is a sequence diagram which shows an example of the flow execution process which concerns on 1st embodiment. 第一の実施形態に係るコンポーネントの追加、更新、及び削除処理の一例を示すシーケンス図である。It is a sequence diagram showing an example of addition, update, and deletion processing of the component concerning a first embodiment. コンポーネント編集画面、コンポーネント追加画面、及びコンポーネント更新画面の一例を示す図である。It is a figure which shows an example of a component edit screen, a component addition screen, and a component update screen. 第二の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。It is a figure which shows the processing block of an example of the logic processing part which concerns on 2nd embodiment. 第二の実施形態に係るコンポーネント情報テーブルの一例を示す図である。It is a figure which shows an example of the component information table which concerns on 2nd embodiment. 第二の実施形態に係るフロー実行処理の一例を示すシーケンス図である。It is a sequence diagram which shows an example of the flow execution process which concerns on 2nd embodiment. 第三の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。It is a figure which shows the processing block of an example of the logic processing part which concerns on 3rd embodiment. 第三の実施形態に係るコンポーネント情報テーブルの一例を示す図である。It is a figure which shows an example of the component information table which concerns on 3rd embodiment. 第三の実施形態に係るフロー実行処理の一例を示すシーケンス図である。It is a sequence diagram which shows an example of the flow execution process which concerns on 3rd embodiment.

以下、本発明の実施形態について図面を参照しながら詳細に説明する。   Hereinafter, embodiments of the present invention will be described in detail with reference to the drawings.

[第一の実施形態]
<システム構成>
まず、本実施形態に係る情報処理システム1のシステム構成について、図1を参照しながら説明する。図1は、第一の実施形態に係る情報処理システムの一例のシステム構成を示す図である。
First Embodiment
<System configuration>
First, the system configuration of the information processing system 1 according to the present embodiment will be described with reference to FIG. FIG. 1 is a diagram showing a system configuration of an example of the information processing system according to the first embodiment.

図1に示す情報処理システム1は、サービス提供環境E1、ユーザ環境E2、及び外部ストレージシステム40を含み、インターネット等の広域的なネットワークN1を介して通信可能に接続されている。   An information processing system 1 shown in FIG. 1 includes a service providing environment E1, a user environment E2, and an external storage system 40, and is communicably connected via a wide area network N1 such as the Internet.

サービス提供環境E1は、ネットワークN1を介してクラウドサービス等の外部サービスを提供するシステム環境である。なお、本実施形態では、外部サービスの具体例としてクラウドサービスを採用して説明するが、ASP(Application Service Provider)によって提供されるサービスやWebサービス等、ネットワークを介して提供されるサービスに関して本実施形態が適用されても良い。   The service providing environment E1 is a system environment that provides an external service such as a cloud service via the network N1. In the present embodiment, a cloud service is adopted and described as a specific example of the external service, but the present embodiment can be applied to a service provided by an application service provider (ASP) or a service provided via a network, such as a web service. A form may be applied.

サービス提供環境E1は、一台以上の情報処理装置で実現されるサービス提供システム10を有する。サービス提供システム10は、ネットワークN1を介して所定のサービスを提供する。例えば、サービス提供システム10は、ユーザ環境E2の画像形成装置20において原稿をスキャンして生成された電子ファイルを、OCR(Optical Character Reader)処理して、外部ストレージシステム40に保存するサービス(スキャン配信サービス)を提供する。本実施形態に係るサービス提供システム10は、このようなスキャン配信サービスを提供する。   The service providing environment E1 has a service providing system 10 realized by one or more information processing apparatuses. The service providing system 10 provides a predetermined service via the network N1. For example, the service providing system 10 performs an OCR (Optical Character Reader) process on an electronic file generated by scanning a document in the image forming apparatus 20 of the user environment E2, and stores the file in the external storage system 40 (scan distribution Provide services). The service providing system 10 according to the present embodiment provides such a scan delivery service.

ただし、サービス提供システム10により提供されるサービスは、これに限られない。サービス提供システム10は、例えば、外部ストレージシステム40に保存されている電子ファイルを、ユーザ環境E2の画像形成装置20で印刷するサービス(クラウドプリントサービス)を提供しても良い。   However, the service provided by the service providing system 10 is not limited to this. The service providing system 10 may provide, for example, a service (cloud print service) for printing an electronic file stored in the external storage system 40 with the image forming apparatus 20 of the user environment E2.

また、サービス提供システム10は、例えば、外部ストレージシステム40に保存されている電子ファイルを、ユーザ環境E2のプロジェクタで投影するサービスを提供しても良い。さらに、サービス提供システム10は、画像形成装置20において原稿をスキャンして生成された電子ファイルを、OCR処理した後、所定の言語に翻訳(例えば、英語から日本語に翻訳)して、外部ストレージシステム40に保存するサービスを提供しても良い。このように、本実施形態に係るサービス提供システム10は、外部ストレージシステム40と連携した一連の処理により実現される各種のサービスを提供する。   Also, the service providing system 10 may provide, for example, a service of projecting an electronic file stored in the external storage system 40 with a projector of the user environment E2. Furthermore, the service providing system 10 performs an OCR process on an electronic file generated by scanning a document in the image forming apparatus 20, and translates it into a predetermined language (for example, translates it from English into Japanese), and stores the external storage Services stored in the system 40 may be provided. As described above, the service providing system 10 according to the present embodiment provides various services realized by a series of processes in cooperation with the external storage system 40.

なお、サービス提供システム10の全部又は一部は、ユーザ環境E2に設置されていても良い。すなわち、サービス提供システム10を構成する情報処理装置の全部又は一部は、ユーザ環境E2に包含されていても良い。   Note that all or part of the service providing system 10 may be installed in the user environment E2. That is, all or a part of the information processing apparatus constituting the service providing system 10 may be included in the user environment E2.

ユーザ環境E2は、例えば、画像形成装置20を使用するユーザである企業等におけるシステム環境である。ユーザ環境E2は、一台以上の画像形成装置20、及び一台以上のPC端末30を含み、例えばLAN(Local Area Network)等のネットワークを介して接続されている。   The user environment E2 is, for example, a system environment in a company or the like who is a user who uses the image forming apparatus 20. The user environment E2 includes one or more image forming apparatuses 20 and one or more PC terminals 30, and is connected via a network such as a LAN (Local Area Network).

本実施形態に係る画像形成装置20は、スキャン機能を有するMFP(Multifunction Peripheral)等の複合機である。なお、画像形成装置20は、スキャン機能以外に、プリント機能やコピー機能、ファクス(FAX)通信機能等を有していても良い。   The image forming apparatus 20 according to the present embodiment is a multifunction peripheral such as an MFP (Multifunction Peripheral) having a scan function. The image forming apparatus 20 may have a print function, a copy function, a fax (FAX) communication function, and the like in addition to the scan function.

また、本実施形態に係るPC端末30は、サービス提供システム10が各種のサービスを提供するためのプログラムの開発等に用いられる情報処理装置である。ユーザは、PC端末30を用いて、所定の処理を実行するプログラムやモジュール等をサービス提供システム10に追加等することができる。   The PC terminal 30 according to the present embodiment is an information processing apparatus used for developing a program for the service providing system 10 to provide various services. The user can use the PC terminal 30 to add a program, a module or the like that executes predetermined processing to the service providing system 10 or the like.

外部ストレージシステム40は、ネットワークN1を介してストレージサービス(又はオンラインストレージ)と呼ばれるクラウドサービスを提供するコンピュータシステムである。   The external storage system 40 is a computer system that provides a cloud service called storage service (or online storage) via the network N1.

ストレージサービスとは、外部ストレージシステム40のストレージの記憶領域を貸し出すサービスである。本実施形態では、スキャン配信サービスにおいて、外部ストレージシステム40によって貸し出される記憶領域に、OCR処理された電子ファイルを保存(アップロード)する。   The storage service is a service that lends the storage area of the storage of the external storage system 40. In this embodiment, in the scan distribution service, the OCR processed electronic file is stored (uploaded) in the storage area lent by the external storage system 40.

なお、以降では、複数の外部ストレージシステム40について、各々を区別するときは、「外部ストレージシステム40」、「外部ストレージシステム40」等と添え字を用いて記載する。また、外部ストレージシステム40によって提供されるサービスの名称を「ストレージサービスA」、外部ストレージシステム40によって提供されるサービスの名称を「ストレージサービスB」等とする。 Hereinafter, the plurality of external storage systems 40 will be described using subscripts such as “external storage system 40 1 ”, “external storage system 40 2 ”, etc. Further, "Storage Service A" the name of the service provided by the external storage system 40 1, the names of the services provided by the external storage system 40 2, "Storage Service B", and the like.

外部ストレージシステム40は、複数台の情報処理装置によって実現されるシステムであっても良い。また、図1に示す情報処理システム1の構成は一例であって、他の構成であっても良い。例えば、ユーザ環境E2は、画像形成装置20に加えて又は画像形成装置20に代えて、プロジェクタ、電子黒板等の各種機器を有していても良い。   The external storage system 40 may be a system realized by a plurality of information processing devices. The configuration of the information processing system 1 shown in FIG. 1 is an example, and may be another configuration. For example, the user environment E2 may include various devices such as a projector and an electronic blackboard in addition to or in place of the image forming apparatus 20.

<ハードウェア構成>
≪サービス提供システム、PC端末≫
サービス提供システム10及びPC端末30のハードウェア構成について、図2を参照しながら説明する。図2は、第一の実施形態に係るサービス提供システム及びPC端末の一例のハードウェア構成を示す図である。なお、サービス提供システム10及びPC端末30は、同様のハードウェア構成を有しているため、以降では、主に、サービス提供システム10のハードウェア構成について説明する。
<Hardware configuration>
«Service provision system, PC terminal»
The hardware configuration of the service providing system 10 and the PC terminal 30 will be described with reference to FIG. FIG. 2 is a diagram showing a hardware configuration of an example of the service providing system and the PC terminal according to the first embodiment. Since the service providing system 10 and the PC terminal 30 have the same hardware configuration, the hardware configuration of the service providing system 10 will be mainly described hereinafter.

サービス提供システム10は、入力装置11、表示装置12、外部I/F13、及びRAM(Random Access Memory)14を有する。また、サービス提供システム10は、ROM(Read Only Memory)15、CPU(Central Processing Unit)16、通信I/F17、及びHDD(Hard Disk Drive)18を有する。これらの各ハードウェアは、それぞれがバスBで接続されている。   The service providing system 10 includes an input device 11, a display device 12, an external I / F 13, and a random access memory (RAM) 14. The service providing system 10 further includes a read only memory (ROM) 15, a central processing unit (CPU) 16, a communication I / F 17, and a hard disk drive (HDD) 18. Each of these pieces of hardware is connected by a bus B.

入力装置11は、キーボードやマウス、タッチパネル等を含み、ユーザが各操作信号を入力するのに用いられる。表示装置12は、ディスプレイ等を含み、サービス提供システム10による処理結果を表示する。なお、入力装置11及び表示装置12は、必要なときにバスBに接続して利用する形態であっても良い。   The input device 11 includes a keyboard, a mouse, a touch panel, and the like, and is used by the user to input each operation signal. The display device 12 includes a display and the like, and displays the processing result by the service providing system 10. The input device 11 and the display device 12 may be connected to the bus B when necessary and used.

通信I/F17は、サービス提供システム10をネットワークN1に接続するインタフェースである。これにより、サービス提供システム10は、通信I/F17を介してデータ通信を行うことができる。   The communication I / F 17 is an interface that connects the service providing system 10 to the network N1. Thus, the service providing system 10 can perform data communication via the communication I / F 17.

HDD18は、プログラムやデータを格納している不揮発性の記憶装置である。格納されるプログラムやデータには、サービス提供システム10全体を制御する基本ソフトウェアであるOS(Operating System)、及びOS上において各種機能を提供するアプリケーションソフトウェア等がある。   The HDD 18 is a non-volatile storage device storing programs and data. The programs and data to be stored include an operating system (OS) which is basic software for controlling the entire service providing system 10, application software for providing various functions on the OS, and the like.

なお、サービス提供システム10は、HDD18に代えて又はHDD18に加えて、フラッシュメモリを用いるドライブ装置(例えばソリッドステートドライブ:SSD)を利用しても良い。また、HDD18は、格納しているプログラムやデータを所定のファイルシステム及び/又はDBにより管理している。   The service providing system 10 may use a drive device (for example, solid state drive: SSD) using a flash memory, instead of or in addition to the HDD 18. Further, the HDD 18 manages stored programs and data by a predetermined file system and / or DB.

外部I/F13は、外部装置とのインタフェースである。外部装置には、記録媒体13a等がある。これにより、サービス提供システム10は、外部I/F13を介して記録媒体13aの読み取り及び/又は書き込みを行うことができる。記録媒体13aには、フレキシブルディスク、CD、DVD、SDメモリカード、USBメモリ等がある。   The external I / F 13 is an interface with an external device. The external device is, for example, a recording medium 13a. Thereby, the service providing system 10 can read and / or write the recording medium 13 a via the external I / F 13. The recording medium 13a includes a flexible disk, a CD, a DVD, an SD memory card, a USB memory, and the like.

ROM15は、電源を切ってもプログラムやデータを保持することができる不揮発性の半導体メモリである。ROM15には、サービス提供システム10の起動時に実行されるBIOS(Basic Input/Output System)、OS設定、及びネットワーク設定等のプログラムやデータが格納されている。RAM14は、プログラムやデータを一時保持する揮発性の半導体メモリである。   The ROM 15 is a non-volatile semiconductor memory that can hold programs and data even after the power is turned off. The ROM 15 stores programs and data such as a BIOS (Basic Input / Output System), an OS setting, and a network setting which are executed when the service providing system 10 is started. The RAM 14 is a volatile semiconductor memory that temporarily holds programs and data.

CPU16は、ROM15やHDD18等からプログラムやデータをRAM14上に読み出し、処理を実行することで、サービス提供システム10全体の制御や機能を実現する演算装置である。   The CPU 16 is an arithmetic device that implements control and functions of the entire service providing system 10 by reading programs and data from the ROM 15, the HDD 18 or the like onto the RAM 14 and executing processing.

本実施形態に係るサービス提供システム10及びPC端末30は、上記のハードウェア構成を有することにより、後述するような各種処理を実現できる。   The service providing system 10 and the PC terminal 30 according to the present embodiment can realize various processes to be described later by having the above-described hardware configuration.

≪画像形成装置≫
画像形成装置20のハードウェア構成について、図3を参照しながら説明する。図3は、第一の実施形態に係る画像形成装置の一例のハードウェア構成を示す図である。
<< image forming device >>
The hardware configuration of the image forming apparatus 20 will be described with reference to FIG. FIG. 3 is a diagram illustrating a hardware configuration of an example of the image forming apparatus according to the first embodiment.

画像形成装置20は、コントローラ21、操作パネル22、外部I/F23、通信I/F24、プリンタ25、及びスキャナ26を有する。また、コントローラ21は、CPU211、RAM212、ROM213、NVRAM214、及びHDD215を有する。   The image forming apparatus 20 includes a controller 21, an operation panel 22, an external I / F 23, a communication I / F 24, a printer 25, and a scanner 26. The controller 21 further includes a CPU 211, a RAM 212, a ROM 213, an NVRAM 214, and an HDD 215.

ROM213は、各種プログラムやデータを格納する。RAM212は、プログラムやデータを一時保持する。NVRAM214は、例えば設定情報等が格納されている。また、HDD215は、各種プログラムやデータを格納する。   The ROM 213 stores various programs and data. The RAM 212 temporarily holds programs and data. The NVRAM 214 stores, for example, setting information and the like. The HDD 215 also stores various programs and data.

CPU211は、ROM213やNVRAM214、HDD215等からプログラムやデータ、設定情報等をRAM212上に読み出し、処理を実行することで、画像形成装置20全体の制御や機能を実現する。   The CPU 211 reads programs, data, setting information, and the like from the ROM 213, the NVRAM 214, the HDD 215, and the like onto the RAM 212 and executes processing to realize control and functions of the entire image forming apparatus 20.

操作パネル22は、ユーザからの入力を受け付ける入力部と、表示を行う表示部とを備えている。外部I/F23は、外部装置とのインタフェースである。外部装置には、記録媒体23a等がある。これにより、画像形成装置20は、外部I/F23を介して記録媒体23aの読み取り及び/又は書き込みを行うことができる。記録媒体23aにはICカード、フレキシブルディスク、CD、DVD、SDメモリカード、USBメモリ等がある。   The operation panel 22 includes an input unit that receives an input from a user, and a display unit that performs display. The external I / F 23 is an interface with an external device. The external device is, for example, a recording medium 23a. Thereby, the image forming apparatus 20 can read and / or write the recording medium 23 a via the external I / F 23. The recording medium 23a includes an IC card, a flexible disk, a CD, a DVD, an SD memory card, a USB memory, and the like.

通信I/F24は、画像形成装置20をネットワークN1に接続するインタフェースである。これにより、画像形成装置20は通信I/F24を介してデータ通信を行うことができる。プリンタ25は、印刷データを印刷するための印刷装置である。スキャナ26は原稿を読み取り画像ファイル(電子ファイル)を生成するための読取装置である。   The communication I / F 24 is an interface that connects the image forming apparatus 20 to the network N1. Thus, the image forming apparatus 20 can perform data communication via the communication I / F 24. The printer 25 is a printing device for printing print data. The scanner 26 is a reading device for reading an original and generating an image file (electronic file).

本実施形態に係る画像形成装置20は、上記のハードウェア構成を有することにより、後述するような各種処理を実現できる。   The image forming apparatus 20 according to the present embodiment can realize various processes to be described later by having the above-described hardware configuration.

<ソフトウェア構成>
次に、本実施形態に係る情報処理システム1の処理ブロックについて、図4を参照しながら説明する。図4は、第一の実施形態に係る情報処理システムの一例の処理ブロックを示す図である。
<Software configuration>
Next, processing blocks of the information processing system 1 according to the present embodiment will be described with reference to FIG. FIG. 4 is a diagram showing processing blocks of an example of the information processing system according to the first embodiment.

図4に示す画像形成装置20は、例えばCPU211等により実行されるブラウザ210を有する。画像形成装置20のユーザは、ブラウザ210を介して、サービス提供システム10により提供されるサービスを利用することができる。このように、本実施形態に係る画像形成装置20では、ブラウザ210が搭載(インストール)されていれば良く、サービスを利用するための専用のアプリケーションが搭載されている必要がない。   The image forming apparatus 20 illustrated in FIG. 4 has a browser 210 executed by, for example, the CPU 211 or the like. The user of the image forming apparatus 20 can use the service provided by the service providing system 10 via the browser 210. As described above, in the image forming apparatus 20 according to the present embodiment, the browser 210 may be installed (installed), and it is not necessary to install a dedicated application for using the service.

図4に示すPC端末30は、例えばCPU16等により実行されるブラウザ310を有する。PC端末30のユーザは、ブラウザ310を介して、所定の処理を実行するプログラムやモジュール等(すなわち、後述する「コンポーネント」)をサービス提供システム10に追加することができる。これにより、本実施形態に係るサービス提供システム10では、PC端末30から追加されたコンポーネントにより実現されるサービスを追加することができる。   The PC terminal 30 shown in FIG. 4 has a browser 310 executed by, for example, the CPU 16 or the like. The user of the PC terminal 30 can add a program, a module or the like (that is, a “component” to be described later) that executes predetermined processing to the service providing system 10 via the browser 310. Thereby, in the service providing system 10 according to the present embodiment, services realized by the components added from the PC terminal 30 can be added.

ここで、コンポーネントとは、サービス提供システム10により提供されるサービスを実現するための一連の処理に含まれる一の処理を実行するためのモジュール等である。   Here, the component is a module or the like for executing one process included in a series of processes for realizing the service provided by the service providing system 10.

図4に示すサービス提供システム10は、サービス処理部110、ドキュメントサービス部150、及びストレージサービス連携部160を有する。これら各部は、サービス提供システム10に搭載された1以上のプログラムが、CPU16に実行させる処理により実現される。   The service providing system 10 illustrated in FIG. 4 includes a service processing unit 110, a document service unit 150, and a storage service cooperation unit 160. These units are realized by processing that one or more programs installed in the service providing system 10 cause the CPU 16 to execute.

また、サービス提供システム10は、アプリ情報記憶部190を有する。アプリ情報記憶部190は、HDD18により実現可能である。なお、アプリ情報記憶部190は、サービス提供システム10とネットワークN1を介して接続される記憶装置等により実現されても良い。   Further, the service providing system 10 includes an application information storage unit 190. The application information storage unit 190 can be realized by the HDD 18. The application information storage unit 190 may be realized by a storage device connected with the service providing system 10 via the network N1.

サービス処理部110は、画像形成装置20のブラウザ210からの要求に応じて、各種のサービスに関する処理を実行する。サービス処理部110は、アプリ管理部120、ロジック処理部130、及びデータI/F部140を有する。   The service processing unit 110 executes processing relating to various services in response to a request from the browser 210 of the image forming apparatus 20. The service processing unit 110 includes an application management unit 120, a logic processing unit 130, and a data I / F unit 140.

アプリ管理部120は、アプリ情報記憶部190に記憶されているアプリ情報1000を管理する。アプリ管理部120は、画像形成装置20のブラウザ210からの要求に応じて、アプリ情報1000に含まれる画面定義に基づくアプリ画面を返信する。これにより、画像形成装置20の操作パネル22には、ブラウザ210により、サービス提供システム10により提供されるサービスを利用するためのアプリ画面が表示される。   The application management unit 120 manages application information 1000 stored in the application information storage unit 190. In response to a request from the browser 210 of the image forming apparatus 20, the application management unit 120 sends back an application screen based on the screen definition included in the application information 1000. As a result, on the operation panel 22 of the image forming apparatus 20, the browser 210 displays an application screen for using the service provided by the service providing system 10.

ここで、アプリ情報1000には、アプリ画面を画像形成装置20に表示させるための画面定義と、アプリ画面から利用されるサービスを実現するための処理内容とが含まれる。なお、アプリ情報1000には、複数の画面定義と、複数の処理内容とが含まれていても良い。   Here, the application information 1000 includes a screen definition for causing the image forming apparatus 20 to display an application screen, and processing contents for realizing a service used from the application screen. The application information 1000 may include a plurality of screen definitions and a plurality of processing contents.

また、アプリ管理部120は、ロジック処理部130からの要求に応じて、アプリ情報1000に含まれる処理内容を返信する。処理内容は、サービス提供システム10により提供されるサービスを実現するための一連の処理(一連の処理は「処理フロー」とも称される。)の内容が記述されている。   Further, in response to a request from the logic processing unit 130, the application management unit 120 sends back processing content included in the application information 1000. The processing content describes the content of a series of processing (a series of processing is also referred to as “processing flow”) for realizing the service provided by the service providing system 10.

ロジック処理部130は、画像形成装置20のブラウザ210からの要求に応じて、アプリ管理部120を介して処理内容を取得する。そして、ロジック処理部130は、取得した処理内容に基づく一連の処理を実行する。   The logic processing unit 130 acquires processing content via the application management unit 120 in response to a request from the browser 210 of the image forming apparatus 20. Then, the logic processing unit 130 executes a series of processing based on the acquired processing content.

すなわち、ロジック処理部130は、ドキュメントサービス部150又は/及びストレージサービス連携部160のファイル処理部170に対して、処理内容に従った処理の実行を要求することで、当該処理内容に基づく一連の処理を実行する。これにより、本実施形態に係るサービス提供システム10は、画像形成装置20に対して各種のサービスを提供することができる。なお、ロジック処理部130の詳細な処理ブロックについては、後述する。   That is, the logic processing unit 130 requests the file processing unit 170 of the document service unit 150 and / or the storage service cooperation unit 160 to execute a process according to the process content, whereby a series of processes based on the process content is performed. Execute the process Thus, the service providing system 10 according to the present embodiment can provide various services to the image forming apparatus 20. The detailed processing blocks of the logic processing unit 130 will be described later.

データI/F部140は、画像形成装置20のブラウザ210からの要求に応じて、ストレージサービス連携部160のデータ処理部180に対して、所定の要求(例えば、フォルダ一覧の取得要求等)を行う。   The data I / F unit 140 responds to a request from the browser 210 of the image forming apparatus 20 to the data processing unit 180 of the storage service cooperation unit 160 for a predetermined request (for example, a folder list acquisition request). Do.

ドキュメントサービス部150は、サービス提供システム10により提供されるサービスを実現するためのプログラム(モジュール)群である。ドキュメントサービス部150には、電子ファイルに対してOCR処理を行うOCR処理151が含まれる。なお、ドキュメントサービス部150には、例えば、所定の言語で記載されている文書ファイル(電子ファイル)を他の所定の言語に翻訳する翻訳処理プログラム等の各種プログラムが含まれても良い。   The document service unit 150 is a group of programs (modules) for realizing the service provided by the service providing system 10. The document service unit 150 includes an OCR process 151 for performing an OCR process on the electronic file. The document service unit 150 may include, for example, various programs such as a translation processing program for translating a document file (electronic file) described in a predetermined language into another predetermined language.

ストレージサービス連携部160は、ロジック処理部130やデータI/F部140からの要求に応じて、外部ストレージシステム40に対して、各種処理の実行を要求する。   The storage service cooperation unit 160 requests the external storage system 40 to execute various types of processing in response to requests from the logic processing unit 130 and the data I / F unit 140.

ここで、本実施形態に係るサービス提供システム10は、外部ストレージシステム40毎に、ストレージサービス連携部160を有する。すなわち、サービス提供システム10は、外部ストレージシステム40に対して処理の実行を要求するためのストレージサービスA連携部160、外部ストレージシステム40に対して処理の実行を要求するためのストレージサービスB連携部160等を有する。このように、サービス提供システム10は、当該サービス提供システム10と連携して処理を行う外部ストレージシステム40毎に、それぞれの外部ストレージシステム40に対応するストレージサービス連携部160を有する。 Here, the service providing system 10 according to the present embodiment has a storage service cooperation unit 160 for each external storage system 40. That is, the service providing system 10 includes a storage service for requesting storage service A linkage unit 160 1 for requesting execution of processing to the external storage system 40 1, the execution of processing to the external storage system 40 2 with B linkage unit 160 2. Thus, the service providing system 10 has a storage service cooperation unit 160 corresponding to each external storage system 40 for each external storage system 40 that performs processing in cooperation with the service providing system 10.

なお、以降では、複数のストレージサービス連携部160について、各々を区別するときは、「ストレージサービスA連携部160」、「ストレージサービスB連携部160」等と記載する。 In the following, when the plurality of storage service cooperation units 160 are distinguished from one another, they are described as “storage service A cooperation unit 160 1 ”, “storage service B cooperation unit 160 2 ” or the like.

ストレージサービス連携部160は、上述したように、ロジック処理部130からの要求を受け取るファイル処理部170、及びデータI/F部140からの要求を受け取るデータ処理部180を有する。   As described above, the storage service cooperation unit 160 includes the file processing unit 170 that receives the request from the logic processing unit 130 and the data processing unit 180 that receives the request from the data I / F unit 140.

ファイル処理部170は、外部ストレージシステム40に保存されている電子ファイルに対する操作(例えば、取得、保存、編集等)を行うためのAPI(Application Programming Interface)が定義された共通I/F171及び固有I/F172を有する。   The file processing unit 170 is a common I / F 171 in which an API (Application Programming Interface) for performing an operation (for example, acquisition, storage, editing, etc.) on an electronic file stored in the external storage system 40 is defined. / F 172 is provided.

共通I/F171は、複数の外部ストレージシステム40間で共通に利用できるAPIであり、例えば図5(a)に示すAPIが挙げられる。換言すれば、ファイル処理部170の共通I/F171は、すべての外部ストレージシステム40が利用できるファイル操作に関する機能(例えば、ファイルの取得、保存等)を利用するためのAPI群である。   The common I / F 171 is an API that can be commonly used among a plurality of external storage systems 40, and examples include the API shown in FIG. 5A. In other words, the common I / F 171 of the file processing unit 170 is an API group for using functions (for example, acquisition and storage of files, etc.) related to file operations that all external storage systems 40 can use.

一方、固有I/F172は、特定の外部ストレージシステム40において利用できるAPIであり、例えば図5(b)に示すAPIが挙げられる。換言すれば、ファイル処理部170の固有I/F172は、特定の外部ストレージシステム40において利用できるファイル操作に関する機能(例えば、ファイルの編集等)を利用するためのAPI群である。   On the other hand, the unique I / F 172 is an API that can be used in a specific external storage system 40, and examples include the API shown in FIG. 5 (b). In other words, the unique I / F 172 of the file processing unit 170 is an API group for using a function related to file operation (for example, editing of a file, etc.) that can be used in a specific external storage system 40.

したがって、共通I/F171は、すべてのストレージサービス連携部160に対して同様に定義される。一方で、固有I/F172は、当該固有I/F172で定義されるAPIが利用可能な特定の外部ストレージシステム40に対応するストレージサービス連携部160に対して個別に定義される。   Therefore, the common I / F 171 is similarly defined for all the storage service linkage units 160. On the other hand, the unique I / F 172 is individually defined with respect to the storage service cooperation unit 160 corresponding to the specific external storage system 40 in which the API defined by the unique I / F 172 can be used.

また、データ処理部180は、外部ストレージシステム40に保存されている電子ファイルの書誌情報等のメタデータ(例えば、ファイル一覧、フォルダ一覧等)を取得等するためのAPIが定義された共通I/F181及び固有I/F182を有する。   Also, the data processing unit 180 is a common I / I that defines an API for acquiring metadata (eg, file list, folder list, etc.) such as bibliographic information of electronic files stored in the external storage system 40. It has F181 and a unique I / F 182.

共通I/F181は、複数の外部ストレージシステム40間で共通に利用できるAPIであり、例えば図5(c)に示すAPIが挙げられる。換言すれば、データ処理部180の共通I/F181は、すべての外部ストレージシステム40で利用できるメタデータ取得等の機能を利用するためのAPI群である。   The common I / F 181 is an API that can be commonly used among a plurality of external storage systems 40, and examples thereof include the API shown in FIG. 5C. In other words, the common I / F 181 of the data processing unit 180 is an API group for using a function such as metadata acquisition that can be used by all the external storage systems 40.

一方、固有I/F182は、特定の外部ストレージシステム40において利用できるAPIであり、例えば図5(d)に示すAPIが挙げられる。換言すれば、データ処理部180の固有I/F182は、特定の外部ストレージシステム40において利用できるメタデータ取得等の機能(例えば、画像ファイル一覧の取得等)を利用するためのAPI群である。   On the other hand, the unique I / F 182 is an API that can be used in a specific external storage system 40, and examples include the API shown in FIG. 5 (d). In other words, the unique I / F 182 of the data processing unit 180 is an API group for using a function (for example, acquisition of an image file list and the like) that can be used in a specific external storage system 40 such as metadata acquisition.

したがって、共通I/F181は、すべてのストレージサービス連携部160に対して同様に定義される。一方で、固有I/F182は、当該固有I/F182で定義されるAPIが利用可能な特定の外部ストレージシステム40に対応するストレージサービス連携部160に対して個別に定義される。   Therefore, the common I / F 181 is similarly defined for all the storage service linkage units 160. On the other hand, the unique I / F 182 is individually defined with respect to the storage service cooperation unit 160 corresponding to the specific external storage system 40 in which the API defined in the unique I / F 182 can be used.

以上のように、本実施形態に係るサービス提供システム10は、連携して処理を行う外部ストレージシステム40毎に、それぞれの外部ストレージシステム40に対応するストレージサービス連携部160を有する。このため、本実施形態に係る情報処理システム1では、連携先となる外部ストレージシステム40を追加等する場合には、当該外部ストレージシステム40に対応するストレージサービス連携部160をサービス提供システム10に追加等すれば良い。   As described above, the service providing system 10 according to the present embodiment has the storage service cooperation unit 160 corresponding to each external storage system 40 for each external storage system 40 that performs processing in cooperation. Therefore, in the information processing system 1 according to the present embodiment, when adding the external storage system 40 to be a cooperation destination, the storage service cooperation unit 160 corresponding to the external storage system 40 is added to the service providing system 10 You should do the same.

したがって、本実施形態に係るサービス提供システム10は、連携先となる外部ストレージシステム40の追加等に伴う影響を局所化することができる。換言すれば、他の処理ブロック(サービス処理部110やドキュメントサービス部150等)に影響を与えることなく(すなわち、他の処理ブロックを修正等する必要なく)、連携先となる外部ストレージシステム40の追加等を行うことができる。   Therefore, the service providing system 10 according to the present embodiment can localize the influence associated with the addition of the external storage system 40 as the cooperation destination. In other words, without affecting other processing blocks (such as the service processing unit 110 and the document service unit 150) (that is, there is no need to modify other processing blocks, etc.), It is possible to add and so on.

これにより、本実施形態に係るサービス提供システム10では、連携先の外部ストレージシステム40の追加等の開発に要する工数を削減することができる。なお、ストレージサービス連携部160の追加等は、SDK(Software Development Kit)を用いて行うことができる。   Thereby, in the service providing system 10 according to the present embodiment, it is possible to reduce the number of man-hours required for development such as addition of the external storage system 40 of the cooperation destination. The addition of the storage service cooperation unit 160 can be performed using a software development kit (SDK).

また、ストレージサービス連携部160では、共通I/F171及び固有I/F172がそれぞれ異なるモジュール等で実現される。さらに、共通I/F171及び固有I/F172で定義されるAPIは、「ストレージサービス名」(外部サービス名)を指定することで利用することができる(すなわち、「ストレージサービス名」(外部サービス名)が可変部分となっている)。   Further, in the storage service cooperation unit 160, the common I / F 171 and the unique I / F 172 are realized by different modules or the like. Furthermore, the API defined by common I / F 171 and unique I / F 172 can be used by specifying "storage service name" (external service name) (that is, "storage service name" (external service name) ) Is a variable part).

したがって、連携先の外部ストレージシステム40を追加する場合には、他のストレージサービス連携部160に定義されている共通I/F171を再利用することができる。換言すれば、連携先の外部ストレージシステム40を追加する場合には、当該追加する外部ストレージシステム40の固有I/F172のみを開発すれば良い。これにより、本実施形態に係るサービス提供システム10では、連携先の外部ストレージシステム40の追加等の開発に要する工数をさらに削減することができる。なお、このことは、データ処理部180の共通I/F181及び固有I/F182に関しても同様である。   Therefore, when adding the external storage system 40 of the cooperation destination, the common I / F 171 defined in the other storage service cooperation unit 160 can be reused. In other words, when adding the external storage system 40 of the cooperation destination, it is sufficient to develop only the unique I / F 172 of the external storage system 40 to be added. Thereby, in the service providing system 10 according to the present embodiment, it is possible to further reduce the number of man-hours required for development such as addition of the external storage system 40 of the cooperation destination. The same applies to the common I / F 181 and the unique I / F 182 of the data processing unit 180.

アプリ情報記憶部190は、各種のサービスを提供するためのアプリ情報1000を記憶する。アプリ情報1000は、アプリ画面を画像形成装置20に表示させるための画面定義と、アプリ画面から利用されるサービスを実現するための一連の処理の内容が記述された処理内容とを含む。また、アプリ情報1000には、当該アプリ情報1000を一意に識別するためのアプリIDが付与されている。なお、以降では、ストレージサービスAと連携したスキャン配信サービスを提供するためのアプリ情報1000のアプリIDを「app001」とする。   The application information storage unit 190 stores application information 1000 for providing various services. The application information 1000 includes a screen definition for causing the image forming apparatus 20 to display an application screen, and processing content in which the contents of a series of processing for realizing a service used from the application screen are described. Further, an application ID for uniquely identifying the application information 1000 is assigned to the application information 1000. Hereinafter, the application ID of the application information 1000 for providing the scan distribution service in cooperation with the storage service A will be “app001”.

ここで、ストレージサービスAと連携したスキャン配信サービスを提供するためのアプリ情報1000の画面定義に含まれるデータ定義について、図6を参照しながら説明する。図6は、データ定義の一例を示す図である。   Here, the data definition included in the screen definition of the application information 1000 for providing the scan distribution service in cooperation with the storage service A will be described with reference to FIG. FIG. 6 is a diagram showing an example of data definition.

図6に示すデータ定義1100は、画像形成装置20のブラウザ210により操作パネル22等に表示されるアプリ画面の入力欄(入力ボックス)や選択欄(選択ボックス)等を構成するための情報が記述されている。   In the data definition 1100 shown in FIG. 6, information for configuring an input field (input box) and a selection field (selection box) of an application screen displayed on the operation panel 22 etc. by the browser 210 of the image forming apparatus 20 is described. It is done.

具体的には、図6に示すデータ定義1100に含まれるデータ定義部1101には、スキャンにより生成される電子ファイルのファイル名を入力するための入力欄を構成するための情報が記述されている。また、図6に示すデータ定義に含まれるデータ定義部1102には、ストレージサービスAにおける保存先フォルダを選択するための選択欄を構成するための情報が記述されている。   Specifically, the data definition unit 1101 included in the data definition 1100 shown in FIG. 6 describes information for configuring an input field for inputting the file name of the electronic file generated by the scan. . Further, in the data definition unit 1102 included in the data definition shown in FIG. 6, information for configuring a selection field for selecting a storage destination folder in the storage service A is described.

なお、データ定義部1102の「data_source」には、選択欄の各選択要素(ここでは、保存先候補のフォルダ名及びフォルダID)の取得先のURL(Uniform Resource Locator)が記述されている。   In "data_source" of the data definition unit 1102, a URL (Uniform Resource Locator) of acquisition destination of each selection element (here, folder name and folder ID of storage destination candidate) in the selection column is described.

次に、ストレージサービスAと連携したスキャン配信サービスを提供するためのアプリ情報1000の画面定義に含まれるレイアウト情報について、図7を参照しながら説明する。図7は、レイアウト情報の一例を示す図である。   Next, layout information included in the screen definition of the application information 1000 for providing the scan distribution service in cooperation with the storage service A will be described with reference to FIG. FIG. 7 is a diagram showing an example of layout information.

図7に示すレイアウト情報1200は、画像形成装置20のブラウザ210により操作パネル22等に表示されるアプリ画面における文字(入力欄の表示名称等)や入力欄、選択欄等の表示位置や表示名称等の情報が記述されている。   The layout information 1200 shown in FIG. 7 is a display position or display name of a character (display name of an input column, etc.), an input column, a selection column, etc. on the application screen displayed on the operation panel 22 by the browser 210 of the image forming apparatus 20. Information such as is described.

具体的には、図7に示すレイアウト情報1200に含まれるレイアウト定義部1201には、データ定義1100における「"data_id":1」(すなわち、データ定義部1101)の表示位置及び表示名称の情報が記述されている。これにより、アプリ画面には、表示名称が「ファイル名」である入力欄が、1番目の位置に表示される。また、レイアウト情報1200に含まれるレイアウト定義部1202では、データ定義1100における「"data_id":2」(すなわち、データ定義部1102)の表示位置及び表示名称の情報が記述されている。これにより、アプリ画面には、表示名称が「保存先フォルダ選択」である選択欄が、2番目の位置に表示される。   Specifically, in the layout definition unit 1201 included in the layout information 1200 shown in FIG. 7, information on the display position and display name of "" data_id ": 1" (that is, the data definition unit 1101) in the data definition 1100 is stored. It has been described. As a result, in the application screen, an input field whose display name is "file name" is displayed at the first position. Further, in the layout definition unit 1202 included in the layout information 1200, information on the display position and display name of "" data_id ": 2" (that is, the data definition unit 1102) in the data definition 1100 is described. As a result, on the application screen, a selection field whose display name is "Select storage folder" is displayed at the second position.

次に、ストレージサービスAと連携したスキャン配信サービスを提供するためのアプリ情報1000の処理内容について、図8を参照しながら説明する。図8は、処理内容の一例を示す図である。   Next, processing contents of the application information 1000 for providing a scan distribution service in cooperation with the storage service A will be described with reference to FIG. FIG. 8 is a diagram showing an example of processing content.

図8に示す処理内容1300は、ストレージサービスAと連携したスキャン配信サービスを実現するための一連の処理の内容が記述されている。   The process content 1300 shown in FIG. 8 describes the contents of a series of processes for realizing the scan distribution service in cooperation with the storage service A.

具体的には、図8に示す処理内容1300に含まれるフローID定義部1301には、当該処理内容1300を一意に識別するための識別情報であるフローID「flow001」が記述されている。また、図8に示す処理定義部1302及び処理定義部1303には、ストレージサービスAと連携したスキャン配信サービスを実現するための一連の処理の内容が定義されている。   Specifically, the flow ID “flow 001”, which is identification information for uniquely identifying the process content 1300, is described in the flow ID definition unit 1301 included in the process content 1300 shown in FIG. Further, in the process definition unit 1302 and the process definition unit 1303 illustrated in FIG. 8, contents of a series of processes for realizing the scan distribution service in cooperation with the storage service A are defined.

すなわち、処理定義部1302には、スキャンして生成された電子ファイルをOCR処理するための処理の内容が記述されている。また、処理定義部1303には、OCR処理後の電子ファイルをストレージサービスAに配信するための処理の内容が記述されている。このように、アプリ情報1000に含まれる処理内容には、外部ストレージシステム40と連携した一連の処理を構成する一以上の処理の内容が記述されている。   That is, in the process definition unit 1302, the content of the process for performing the OCR process on the electronic file generated by scanning is described. The processing definition unit 1303 describes the contents of processing for distributing the electronic file after the OCR processing to the storage service A. As described above, in the process content included in the application information 1000, the content of one or more processes constituting a series of processes in cooperation with the external storage system 40 is described.

以上のように、本実施形態に係るサービス提供システム10は、画像形成装置20にアプリ画面を表示させるための画面定義と、サービスを実現するための一連の処理(処理フロー)の内容が記述された処理内容とが含まれるアプリ情報1000を有する。そして、本実施形態に係るサービス提供システム10は、画像形成装置20に対して、アプリ情報1000を利用して各種のサービスを提供する。このため、サービス提供システム10により提供されるサービスを追加等する場合には、アプリ情報記憶部190にアプリ情報1000を追加等すれば良い。   As described above, in the service providing system 10 according to the present embodiment, the screen definition for displaying the application screen on the image forming apparatus 20 and the contents of a series of processing (processing flow) for realizing the service are described. The application information 1000 includes the process content. Then, the service providing system 10 according to the present embodiment provides the image forming apparatus 20 with various services using the application information 1000. Therefore, when adding a service provided by the service providing system 10, the application information 1000 may be added to the application information storage unit 190.

また、本実施形態に係るサービス提供システム10にアプリ情報1000を追加するには、画面定義及び処理内容を記述すれば良いため、簡易に開発することができる。したがって、本実施形態に係るサービス提供システム10では、サービスの追加・変更等に伴う開発工数を削減させることができるとともに、例えばサードベンダー等によるサービスの追加・変更等を容易に行うことができる。   Further, in order to add the application information 1000 to the service providing system 10 according to the present embodiment, the screen definition and the processing content may be described, and therefore, the development can be easily performed. Therefore, in the service providing system 10 according to the present embodiment, it is possible to reduce the number of development steps accompanying the addition / change of the service, and easily perform the addition / change or the like of the service by, for example, a third vendor.

<処理の詳細>
次に、本実施形態に係る情報処理システム1の処理の詳細について説明する。
<Details of processing>
Next, details of processing of the information processing system 1 according to the present embodiment will be described.

≪スキャン配信サービスの全体処理≫
本実施形態に係るスキャン配信サービスを画像形成装置20のユーザが利用する場合の全体的な処理について、図9を参照しながら説明する。図9は、第一の実施形態に係るスキャン配信サービスの全体処理の一例を示すシーケンス図である。
«Overall processing of scan delivery service»
An overall process when the user of the image forming apparatus 20 uses the scan distribution service according to the present embodiment will be described with reference to FIG. FIG. 9 is a sequence diagram showing an example of the entire process of the scan distribution service according to the first embodiment.

まず、画像形成装置20のユーザは、ブラウザ210を用いて、サービス提供システム10により提供されるサービスの一覧を取得するための操作を行う。すると、画像形成装置20は、サービスの一覧の取得要求をサービス提供システム10のサービス処理部110に送信する(ステップS901)。サービス処理部110のアプリ管理部120は、当該取得要求を受け取ると、サービス提供システム10により提供されるサービスの一覧を画像形成装置20に送信する。これにより、画像形成装置20の操作パネル22には、ブラウザ210により、サービス提供システム10により提供されるサービスの一覧が表示される。   First, the user of the image forming apparatus 20 uses the browser 210 to perform an operation for acquiring a list of services provided by the service providing system 10. Then, the image forming apparatus 20 transmits a service list acquisition request to the service processing unit 110 of the service providing system 10 (step S901). When the application management unit 120 of the service processing unit 110 receives the acquisition request, the application management unit 120 transmits a list of services provided by the service providing system 10 to the image forming apparatus 20. As a result, the browser 210 displays a list of services provided by the service providing system 10 on the operation panel 22 of the image forming apparatus 20.

なお、サービスの一覧には、例えば、サービス提供システム10により提供されるサービスのサービス名と、当該サービスを提供するためのアプリ情報1000のアプリIDと、当該サービスを実現するための処理内容のフローIDとが含まれる。   In the list of services, for example, the service name of the service provided by the service providing system 10, the application ID of the application information 1000 for providing the service, and the flow of the processing content for realizing the service. ID is included.

ユーザは、画像形成装置20の操作パネル22に表示されたサービスの一覧から、自身が利用を所望するサービスを選択する。すると、ブラウザ210は、ユーザにより選択されたサービスに対応するアプリ情報1000のアプリIDと、処理内容のフローIDとをアプリ管理部120に送信する(ステップS902)。   The user selects a service that he / she desires to use from a list of services displayed on the operation panel 22 of the image forming apparatus 20. Then, the browser 210 transmits the application ID of the application information 1000 corresponding to the service selected by the user and the flow ID of the processing content to the application management unit 120 (step S902).

ここで、本実施形態では、ユーザにより「ストレージサービスAと連携したスキャン配信サービス」の利用が選択されたものとする。したがって、ブラウザ210は、アプリID「app001」と、フローID「flow001」とをアプリ管理部120に送信する。   Here, in the present embodiment, it is assumed that the use of the “scan delivery service in cooperation with storage service A” is selected by the user. Therefore, the browser 210 transmits the application ID “app001” and the flow ID “flow001” to the application management unit 120.

そして、アプリ管理部120は、ブラウザ210から受け取ったアプリID「app001」のアプリ情報1000に含まれる画面定義に基づいてHTML(HyperText Markup Language)形式のアプリ画面を生成し、ブラウザ210に返信する。   Then, the application management unit 120 generates an application screen in the HTML (HyperText Markup Language) format based on the screen definition included in the application information 1000 of the application ID “app001” received from the browser 210, and sends the generated application screen to the browser 210.

画像形成装置20のブラウザ210は、アプリ管理部120からアプリ画面を受け取ると、表示用情報の取得をデータI/F部140に要求する(ステップS903)。   When the browser 210 of the image forming apparatus 20 receives the application screen from the application management unit 120, the browser 210 requests the data I / F unit 140 to acquire display information (step S903).

ここで、表示用情報とは、例えばアプリ画面の選択欄の各選択要素のことである。すなわち、本実施形態では、ブラウザ210は、スキャン配信サービスの配信先(保存先)となるストレージサービスAのフォルダの一覧の取得を、データI/F部140に要求する。   Here, the display information is, for example, each selection element of the selection field of the application screen. That is, in the present embodiment, the browser 210 requests the data I / F unit 140 to acquire a list of folders of the storage service A that is the delivery destination (storage destination) of the scan delivery service.

表示用情報の取得要求は、図6のデータ定義部1102に記述されている「"data_source"」に定義されているURL「http://sample.xxx.co.jp/service-a/data/folders」にHTTPリクエストを送信することで行うことができる。   The request for acquiring the information for display is the URL “http://sample.xxx.co.jp/service-a/data/ defined in“ “data_source” ”described in the data definition unit 1102 of FIG. This can be done by sending an HTTP request to "folders".

なお、当該URLのうち、「http://sample.xxx.co.jp」の部分がサービス提供システム10のホスト名、「/service-a/data/folders」の部分がストレージサービス連携部160におけるAPI(すなわち、図5に示すAPI)の指定となる。   In the URL, the "http://sample.xxx.co.jp" portion is the host name of the service providing system 10, and the "/ service-a / data / folders" portion is the storage service linkage unit 160. It becomes specification of API (that is, API shown in FIG. 5).

次に、データI/F部140は、ブラウザ210から表示用情報の取得要求を受け取ると、当該要求を、対応するストレージサービス連携部160のデータ処理部180に送信する(ステップS904)。すなわち、データI/F部140は、上記のURLに含まれる「service-a」(ストレージサービス名)に基づき、当該要求を、ストレージサービスA連携部160のデータ処理部180に送信する。 Next, when the data I / F unit 140 receives an acquisition request for display information from the browser 210, the data I / F unit 140 transmits the request to the data processing unit 180 of the corresponding storage service cooperation unit 160 (step S904). That is, the data I / F unit 140, based on contained in the above URL "service-a" (storage service name), the request is transmitted to the data processing unit 180 1 of the Storage Service A linkage unit 160 1.

データ処理部180は、データI/F部140から表示用情報の取得要求を受け取ると、当該取得要求に含まれるURLに基づく処理要求を外部ストレージシステム40に送信する(ステップS905)。すなわち、データ処理部180は、データI/F部140から受け取った取得要求に含まれるURLに基づき、共通I/F181又は固有I/F182に定義されているAPIを利用して、該当の外部ストレージシステム40に処理を要求する。   When the data processing unit 180 receives the acquisition request for display information from the data I / F unit 140, the data processing unit 180 transmits a processing request based on the URL included in the acquisition request to the external storage system 40 (step S905). That is, based on the URL included in the acquisition request received from the data I / F unit 140, the data processing unit 180 uses the API defined in the common I / F 181 or the unique I / F 182 to execute the corresponding external storage. Request the system 40 for processing.

より具体的には、上記のURLに含まれる「/service-a/data/folders」に基づき、データ処理部180は、共通I/F181に定義されているAPIを用いて、外部ストレージシステム40にフォルダ一覧の取得を要求する。すると、画像形成装置20のブラウザ210は、ストレージサービスA連携部160を介して、フォルダ一覧を取得する。フォルダ一覧は、本実施形態に係るスキャン配信サービスにおいて、電子ファイルの保存先の候補となるストレージサービスAのフォルダ名及びフォルダID等の情報である。 More specifically, based on the "/ service-a / data / folders" within the above URL, the data processing unit 180 1, using the API defined in the common I / F 181 1, the external storage system 40 Request 1 to obtain folder list. Then, the browser 210 of the image forming apparatus 20 via the storage service A linkage unit 160 1 acquires the folder list. The folder list is information such as a folder name and a folder ID of the storage service A which is a candidate for a storage destination of the electronic file in the scan distribution service according to the present embodiment.

次に、ブラウザ210は、アプリ管理部120から受け取ったアプリ画面と、外部ストレージシステム40から受け取ったフォルダ一覧とに基づき、例えば図10(a)に示すようなアプリ画面2000を、操作パネル22に表示させる(ステップS906)。   Next, based on the application screen received from the application management unit 120 and the folder list received from the external storage system 40, the browser 210 displays, for example, an application screen 2000 as shown in FIG. It is displayed (step S906).

ここで、図10(a)で示すスキャン配信サービスを利用するためのアプリ画面2000は、ファイル名入力欄2001、保存先フォルダ選択欄2002、及びスキャン実行ボタン2003を含む。このうち、ファイル名入力欄2001及び保存先フォルダ選択欄2002は、図10(b)に示すように、それぞれHTMLソースコード2101及び2102で記述されている。このようなHTMLソースコード2101及び2102は、アプリ管理部120により、図6に示すデータ定義部1101及び1102と、図7に示すレイアウト定義部1201及び1202とに基づいて生成される。   Here, the application screen 2000 for using the scan distribution service shown in FIG. 10A includes a file name input field 2001, a storage destination folder selection field 2002, and a scan execution button 2003. Among these, the file name input field 2001 and the save destination folder selection field 2002 are described in HTML source code 2101 and 2102, respectively, as shown in FIG. 10 (b). Such HTML source code 2101 and 2102 are generated by the application management unit 120 based on the data definition units 1101 and 1102 shown in FIG. 6 and the layout definition units 1201 and 1202 shown in FIG.

ただし、HTMLソースコード2102に指定されている「option」の設定値は、外部ストレージシステム40から取得したフォルダ一覧に基づき、ブラウザ210で設定される。このように、アプリ画面2000は、アプリ情報1000に含まれる画面定義に基づきアプリ管理部120で生成されたHTMLに対して、外部ストレージシステム40から取得したフォルダ一覧の情報を設定することで生成される。   However, the setting value of “option” designated in the HTML source code 2102 is set by the browser 210 based on the folder list acquired from the external storage system 40. Thus, the application screen 2000 is generated by setting the information of the folder list acquired from the external storage system 40 to the HTML generated by the application management unit 120 based on the screen definition included in the application information 1000. Ru.

次に、ユーザは、図10(a)のアプリ画面2000において、ファイル名入力欄2001に所望のファイル名を入力して、保存先フォルダ選択欄2002から所望の保存先フォルダを選択する。そして、画像形成装置20のスキャナ26に原稿をセットして、スキャン実行ボタン2003を押下する。すると、画像形成装置20のブラウザ210は、これらの操作を受け付ける(ステップS907)。   Next, the user inputs a desired file name in the file name input field 2001 on the application screen 2000 of FIG. 10A, and selects the desired storage destination folder from the save destination folder selection field 2002. Then, the document is set on the scanner 26 of the image forming apparatus 20, and the scan execution button 2003 is pressed. Then, the browser 210 of the image forming apparatus 20 receives these operations (step S 907).

ここで、ユーザは、ファイル名入力欄2001にファイル名「test」を入力し、保存先フォルダ選択欄2002から「FolderB」を選択して、スキャン実行ボタン2003を押下したものとする。すると、画像形成装置20のスキャナ26により原稿が読み取られ、ファイル名「test」の電子ファイルが生成される(ステップS908)。   Here, it is assumed that the user inputs the file name “test” in the file name input field 2001, selects “Folder B” from the storage destination folder selection field 2002, and presses the scan execution button 2003. Then, the document is read by the scanner 26 of the image forming apparatus 20, and an electronic file having the file name "test" is generated (step S908).

続いて、画像形成装置20のブラウザ210は、スキャン配信サービスの処理実行要求をロジック処理部130に送信する(ステップS909)。ここで、当該実行要求には、アプリID「app001」と、当該アプリIDのアプリ情報1000に含まれる処理内容1300のフローID「flow001」と、生成された電子ファイルと、選択された保存先フォルダ「FolderB」のフォルダID「folder_id_b」とが含まれる。   Subsequently, the browser 210 of the image forming apparatus 20 transmits a processing execution request for the scan distribution service to the logic processing unit 130 (step S909). Here, in the execution request, the application ID “app001”, the flow ID “flow001” of the processing content 1300 included in the application information 1000 of the application ID, the generated electronic file, and the selected storage destination folder The folder ID "folder_id_b" of "Folder B" is included.

ロジック処理部130は、ブラウザ210から処理実行要求を受け取ると、当該処理実行要求に含まれるアプリID及びフローIDに対応する処理内容に基づく一連の処理を実行するフロー実行処理を行う(ステップS910)。これにより、ストレージサービスAと連携したスキャン配信サービスが実現される。なお、フロー実行処理の詳細については後述する。   When the logic processing unit 130 receives the process execution request from the browser 210, the logic process unit 130 executes a flow execution process of executing a series of processes based on the process contents corresponding to the application ID and the flow ID included in the process execution request (step S910). . Thus, a scan distribution service in cooperation with the storage service A is realized. The details of the flow execution process will be described later.

そして、ロジック処理部130は、フロー実行処理の処理結果を、画像形成装置20のブラウザ210に送信する(ステップS911)。これにより、本実施形態に係るスキャン配信サービスが完了する。   Then, the logic processing unit 130 transmits the processing result of the flow execution processing to the browser 210 of the image forming apparatus 20 (step S911). Thus, the scan distribution service according to the present embodiment is completed.

≪フロー実行処理≫
次に、図9のステップS910のフロー実行処理の詳細について説明する。フロー実行処理は、主に、ロジック処理部130により実行される。したがって、フロー実行処理の詳細について説明する前に、ロジック処理部130の詳細な処理ブロックについて、図11を参照しながら説明する。図11は、第一の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。
<< flow execution processing >>
Next, the details of the flow execution process of step S 910 in FIG. 9 will be described. The flow execution process is mainly performed by the logic processing unit 130. Therefore, before describing details of the flow execution process, a detailed processing block of the logic processing unit 130 will be described with reference to FIG. FIG. 11 is a diagram showing a processing block of an example of the logic processing unit according to the first embodiment.

ロジック処理部130は、フロー実行部131、コンポーネント管理部132、コンポーネント群133、型変換管理部134、及び型変換群135を有する。また、ロジック処理部130は、コンポーネント情報テーブル3000、及び型変換テーブル4000を利用する。   The logic processing unit 130 includes a flow execution unit 131, a component management unit 132, a component group 133, a type conversion management unit 134, and a type conversion group 135. Also, the logic processing unit 130 uses the component information table 3000 and the type conversion table 4000.

フロー実行部131は、画像形成装置20のブラウザ210から処理実行要求を受け取ると、アプリ管理部120を介して、アプリ情報1000から処理内容を取得する。そして、フロー実行部131は、取得した処理内容に記述された一連の処理の内容に従って、当該一連の処理に含まれる一の処理を実行するコンポーネントの取得を要求する。また、フロー実行部131は、取得したコンポーネントに対して処理の実行を要求する。   When the flow execution unit 131 receives a process execution request from the browser 210 of the image forming apparatus 20, the flow execution unit 131 acquires the process content from the application information 1000 via the application management unit 120. Then, the flow execution unit 131 requests acquisition of a component that executes one process included in the series of processes according to the contents of the series of processes described in the acquired process content. The flow execution unit 131 also requests the acquired component to execute a process.

コンポーネント管理部132は、フロー実行部131からのコンポーネントの取得要求に応じて、コンポーネントの生成を行う。なお、コンポーネントの生成とは、例えばクラスで定義されたコンポーネントを、メモリ(例えばRAM14)上に展開することを意味する。   The component management unit 132 generates a component in response to the component acquisition request from the flow execution unit 131. The generation of the component means, for example, expanding the component defined by the class on the memory (for example, the RAM 14).

コンポーネント管理部132は、コンポーネント判別部1321、既存コンポーネント生成部1322、追加コンポーネント生成部1323、及びコンポーネント登録部1324を有する。   The component management unit 132 includes a component determination unit 1321, an existing component generation unit 1322, an additional component generation unit 1323, and a component registration unit 1324.

コンポーネント判別部1321は、フロー実行部131からのコンポーネントの取得要求に応じて、コンポーネント情報テーブル3000を参照し、当該取得要求に係るコンポーネントが、既存コンポーネント又は追加コンポーネントのいずれであるかを判別する。   The component determination unit 1321 refers to the component information table 3000 according to the component acquisition request from the flow execution unit 131, and determines whether the component related to the acquisition request is an existing component or an additional component.

ここで、既存コンポーネントとは、サービス提供システム10に予め組み込まれているコンポーネントのことを言う。一方、追加コンポーネントとは、ユーザがPC端末30を介して、コンポーネント情報テーブル3000に登録されたコンポーネントのことを言う。換言すれば、追加コンポーネントとは、ユーザにより開発等され、サービス提供システム10に追加されたコンポーネントのことである。   Here, the existing component refers to a component that is incorporated in the service providing system 10 in advance. On the other hand, the additional component means a component registered in the component information table 3000 by the user via the PC terminal 30. In other words, the additional component is a component developed by the user and added to the service providing system 10.

このように、本実施形態に係るサービス提供システム10では、ユーザにより開発等されたコンポーネントを追加することができる。このため、ユーザは、追加コンポーネントを用いて実現される一連の処理を処理内容として記述することができるため、様々なサービスを提供するアプリ情報1000を開発することができるようになる。   Thus, in the service providing system 10 according to the present embodiment, components developed by the user can be added. Therefore, the user can describe a series of processes implemented using the additional component as process content, and can develop the application information 1000 providing various services.

既存コンポーネント生成部1322は、コンポーネント判別部1321によりコンポーネントの取得要求に係るコンポーネントが既存コンポーネントであると判別された場合、当該取得要求に係る既存コンポーネントを生成する。   If the component determination unit 1321 determines that the component related to the component acquisition request is an existing component, the existing component generation unit 1322 generates an existing component related to the acquisition request.

追加コンポーネント生成部1323は、コンポーネント判別部1321によりコンポーネントの取得要求に係るコンポーネントが追加コンポーネントであると判別された場合、当該取得要求に係る追加コンポーネントを生成する。   When the component determination unit 1321 determines that the component related to the component acquisition request is an additional component, the additional component generation unit 1323 generates an additional component related to the acquisition request.

コンポーネント登録部1324は、PC端末30のブラウザ310からの要求に応じて、追加コンポーネントをコンポーネント情報テーブル3000に登録する。また、コンポーネント登録部1324は、PC端末30のブラウザ310からの要求に応じて、コンポーネント情報テーブル3000に登録されている追加コンポーネントの更新や削除を行う。   The component registration unit 1324 registers the additional component in the component information table 3000 in response to a request from the browser 310 of the PC terminal 30. Further, in response to a request from the browser 310 of the PC terminal 30, the component registration unit 1324 updates or deletes additional components registered in the component information table 3000.

ここで、コンポーネント情報テーブル3000について、図12を参照しながら説明する。図12は、第一の実施形態に係るコンポーネント情報の一例を示す図である。   Here, the component information table 3000 will be described with reference to FIG. FIG. 12 is a diagram showing an example of component information according to the first embodiment.

図12に示すコンポーネント情報テーブル3000は、コンポーネント毎に、コンポーネントに関する情報(コンポーネント情報)を管理する。コンポーネント情報は、データ項目として、コンポーネント名、バージョン、パラメータ、及びファイルを有する。   The component information table 3000 illustrated in FIG. 12 manages information (component information) on components for each component. Component information has component names, versions, parameters, and files as data items.

コンポーネント名は、コンポーネントの情報である。バージョンは、コンポーネントのバージョンである。各コンポーネントは、コンポーネント名及びバージョンにより一意に識別される。   The component name is information on the component. The version is the version of the component. Each component is uniquely identified by component name and version.

パラメータは、コンポーネントに対する入力パラメータである。例えば、外部ストレージシステム40に電子ファイルを配信するためのコンポーネント(後述する配信コンポーネント)のパラメータは、当該外部ストレージシステム40における保存先のフォルダのフォルダID等である。   The parameters are input parameters for the component. For example, the parameter of the component for distributing the electronic file to the external storage system 40 (distribution component to be described later) is a folder ID or the like of the storage destination folder in the external storage system 40.

ファイルは、コンポーネントを生成するための電子ファイル(以降では、この電子ファイルを「生成ファイル」と表す。)が、例えばJAR(Java Archive)等のデータ形式で格納される。したがって、本実施形態では、追加コンポーネントのコンポーネント情報のデータ項目「ファイル」には、当該追加コンポーネントの生成ファイルが格納される。一方で、既存コンポーネントのコンポーネント情報のデータ項目「ファイル」には、生成ファイルが格納されない。   In the file, an electronic file for generating a component (hereinafter, this electronic file is referred to as “generated file”) is stored, for example, in a data format such as JAR (Java Archive). Therefore, in the present embodiment, the data item "file" of the component information of the additional component stores the generated file of the additional component. On the other hand, the generated file is not stored in the data item "file" of the component information of the existing component.

より具体的には、図12に示すコンポーネント情報テーブル3000において、コンポーネント名「ocrA」、バージョン「v1」のコンポーネント情報のデータ項目「ファイル」には、生成ファイルが格納されていない。一方で、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報のデータ項目「ファイル」には、コンポーネントの生成ファイルが格納されている。   More specifically, in the component information table 3000 shown in FIG. 12, the generated file is not stored in the data item "file" of the component information of the component name "ocrA" and the version "v1". On the other hand, a component generated file is stored in the data item “file” of the component information of the component name “ocrB” and the version “v2”.

したがって、図12に示すコンポーネント情報テーブル3000において、コンポーネント名「ocrA」、バージョン「v1」のコンポーネント情報は、既存コンポーネントのコンポーネント情報である。一方で、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報は、追加コンポーネントのコンポーネント情報である。   Therefore, in the component information table 3000 shown in FIG. 12, the component information of the component name “ocrA” and version “v1” is component information of the existing component. On the other hand, the component information of the component name “ocrB” and version “v2” is component information of the additional component.

コンポーネント群133は、既存コンポーネントや追加コンポーネントの集合である。コンポーネント群133には、コンポーネント名「ocrA」、バージョン「v1」のコンポーネント情報に対応するOCRAコンポーネント1331が含まれる。また、コンポーネント群133には、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報に対応するOCRBコンポーネント1332が含まれる。   The component group 133 is a collection of existing components and additional components. The component group 133 includes an OCRA component 1331 corresponding to component information of component name “ocrA” and version “v1”. The component group 133 also includes an OCRB component 1332 corresponding to component information of component name “ocrB” and version “v2”.

同様に、コンポーネント群133には、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報に対応する配信Aコンポーネント1333が含まれる。また、コンポーネント群133には、コンポーネント名「uploadB」、バージョン「v1」のコンポーネント情報に対応する配信Bコンポーネント1334が含まれる。   Similarly, the component group 133 includes a delivery A component 1333 corresponding to component information of component name “uploadA” and version “v1”. Also, the component group 133 includes a distribution B component 1334 corresponding to component information of component name “upload B” and version “v1”.

このように、コンポーネント群133は、コンポーネント情報テーブル3000で管理されているコンポーネント情報に対応するコンポーネントの集合である。   Thus, the component group 133 is a collection of components corresponding to component information managed in the component information table 3000.

さらに、コンポーネント群133に含まれる各コンポーネントは、コンポーネント共通I/F1330を有する。コンポーネント共通I/F1330は、各コンポーネントに対して共通に定義されたAPIであり、コンポーネントを生成するためのAPIと、コンポーネントに対して処理の実行を要求するためのAPIとが含まれる。   Furthermore, each component included in the component group 133 has a component common I / F 1330. The component common I / F 1330 is an API defined in common to each component, and includes an API for generating a component and an API for requesting a component to execute processing.

このように、各コンポーネントがコンポーネント共通I/F1330を有することで、コンポーネントの追加等に伴う影響を局所化することができる。換言すれば、フロー実行部131やコンポーネント管理部132、他のコンポーネント等に影響を与えることなく、コンポーネントの追加等を行うことができる。このため、コンポーネントの追加等の開発に要する工数を削減することができる。   In this manner, each component may have the component common I / F 1330 to localize the effects associated with the addition of components and the like. In other words, components can be added without affecting the flow execution unit 131, the component management unit 132, other components, and the like. Therefore, it is possible to reduce the number of man-hours required for development such as addition of components.

型変換管理部134は、データ型の型変換を管理する。ここで、各コンポーネントは、自身が扱えるデータ型が予め定められている。したがって、型変換管理部134は、コンポーネントからの要求に応じて、型変換テーブル4000を参照して、当該要求に応じた型変換を生成する。   The type conversion management unit 134 manages type conversion of data types. Here, each component has a predetermined data type that can be handled by itself. Therefore, the type conversion management unit 134 generates type conversion according to the request with reference to the type conversion table 4000 in response to a request from the component.

ここで、型変換テーブル4000について、図13を参照しながら説明する。図13は、型変換テーブルの一例を示す図である。   Here, the type conversion table 4000 will be described with reference to FIG. FIG. 13 is a diagram showing an example of a type conversion table.

図13に示す型変換テーブル4000は、型変換に関する情報(型変換情報)を管理する。型変換情報は、データ項目として、変換前のデータ型、変換後のデータ型、及び生成する型変換を有する。これにより、例えば、コンポーネントから「InputStream」のデータ型を「LocalFilePath」のデータ型に変換する要求を受け取った場合、型変換管理部134は、後述する第1の型変換1351を生成する。   The type conversion table 4000 shown in FIG. 13 manages information related to type conversion (type conversion information). Type conversion information includes, as data items, a data type before conversion, a data type after conversion, and type conversion to be generated. Thus, for example, when the component receives a request to convert the data type of “InputStream” to the data type of “LocalFilePath”, the type conversion management unit 134 generates a first type conversion 1351 described later.

そして、型変換管理部134は、生成された型変換に対して型変換処理の実行を要求する。ここで、型変換とは、データ型の型変換処理を実行するためのモジュール等であり、例えばクラスや関数等で定義される。   Then, the type conversion management unit 134 requests the generated type conversion to execute type conversion processing. Here, type conversion is a module or the like for executing type conversion processing of data type, and is defined by, for example, a class or function.

なお、型変換の生成とは、例えばクラスで定義された型変換を、メモリ(例えばRAM14)上に展開することを意味する。また、データ型には、例えば、ストリームデータを示すデータ型「InputStream」、記憶装置等に格納されている電子ファイルのパス(アドレス)を示す「LocalFilePath」、電子ファイルの実体を示す「File」等が挙げられる。   Note that generation of type conversion means that, for example, type conversion defined by a class is expanded on a memory (for example, the RAM 14). Further, as data types, for example, data type “InputStream” indicating stream data, “Local File Path” indicating a path (address) of an electronic file stored in a storage device or the like, “File” indicating an entity of the electronic file, etc. Can be mentioned.

型変換群135は、型変換の集合である。型変換群135には、データ型「InputStream」を「LocalFilePath」に変換する第1の型変換1351が含まれる。型変換群135には、第1の型変換1351以外にも、例えば、「LocalFilePath」を「File」に変換する第2の型変換等が含まれる。   The type conversion group 135 is a set of type conversions. The type conversion group 135 includes a first type conversion 1351 that converts the data type “InputStream” into “LocalFilePath”. The type conversion group 135 includes, in addition to the first type conversion 1351, for example, a second type conversion that converts “Local File Path” into “File”.

さらに、これらの各型変換は、型変換共通I/F1350を有する。型変換共通I/F1350は、各型変換に対して共通に定義されたAPIであり、型変換を生成するためのAPIと、型変換に対して処理の実行を要求するためのAPIとが含まれる。このように、各型変換が型変換共通I/F1350を有するようにすることで、型変換の追加等に伴う影響を局所化することができる。換言すれば、型変換管理部134に影響を与えることなく、コンポーネントの追加等を行うことができる。これにより、型変換の追加等の開発に要する工数を削減することができる。   Furthermore, each of these type conversions has a type conversion common I / F 1350. The type conversion common I / F 1350 is an API defined in common for each type conversion, and includes an API for generating type conversion and an API for requesting execution of processing for type conversion. Be In this way, by making each type conversion have a type conversion common I / F 1350, it is possible to localize the effects accompanying the addition of type conversion and the like. In other words, components can be added without affecting the type conversion management unit 134. This can reduce the number of man-hours required for development such as addition of type conversion.

続いて、図9のステップS910のフロー実行処理の詳細について、図14を参照しながら説明する。図14は、第一の実施形態に係るフロー実行処理の一例を示すシーケンス図である。   Subsequently, the details of the flow execution process of step S 910 in FIG. 9 will be described with reference to FIG. FIG. 14 is a sequence diagram showing an example of the flow execution process according to the first embodiment.

まず、フロー実行部131は、ブラウザ210からスキャン配信サービスの処理実行要求を受け付けると、アプリ管理部120に処理内容の取得を要求する(ステップS1401)。ここで、当該処理内容の取得要求には、アプリID「app001」と、フローID「flow001」とが含まれる。   First, when the flow execution unit 131 receives a process execution request for a scan distribution service from the browser 210, the flow execution unit 131 requests the application management unit 120 to acquire the process content (step S1401). Here, the acquisition request for the process content includes the application ID “app001” and the flow ID “flow001”.

そして、フロー実行部131は、アプリ管理部120からアプリID「app001」に対応するアプリ情報1000に含まれるフローID「flow001」処理内容を取得する。すなわち、フロー実行部131は、図8に示す処理内容1300を取得する。   Then, the flow execution unit 131 acquires, from the application management unit 120, the processing content of the flow ID “flow001” included in the application information 1000 corresponding to the application ID “app001”. That is, the flow execution unit 131 acquires the processing content 1300 shown in FIG.

フロー実行部131は、取得した処理内容1300に従ってコンポーネントの取得を、コンポーネント管理部132に要求する(ステップS1402)。より具体的には、フロー実行部131は、図8に示す処理内容1300の処理定義部1302に記述に基づいて、コンポーネント名「ocrB」、バージョン「v2」のコンポーネントの取得を、コンポーネント管理部132に要求する。   The flow execution unit 131 requests the component management unit 132 to acquire a component according to the acquired processing content 1300 (step S1402). More specifically, the flow execution unit 131 acquires components with the component name “ocrB” and version “v2” based on the description in the process definition unit 1302 of the process content 1300 shown in FIG. To request.

コンポーネント管理部132は、コンポーネントの取得要求を受け取ると、コンポーネント判別部1321により、当該取得要求に係るコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを判別する(ステップS1403)。すなわち、コンポーネント判別部1321は、コンポーネント情報テーブル3000を参照し、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されているか否かを判別する。   When the component management unit 132 receives the component acquisition request, the component determination unit 1321 determines whether the component related to the acquisition request is an existing component or an additional component (step S1403). That is, the component determination unit 1321 refers to the component information table 3000, and determines whether or not the generated file of the component is stored in the data item “file” of the component information of the component name “ocrB” and version “v2”. Do.

コンポーネント判別部1321は、コンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されている場合、取得要求に係るコンポーネントは追加コンポーネントであると判別する。一方、コンポーネント判別部1321は、コンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されていない場合、取得要求に係るコンポーネントは既存コンポーネントであると判別する。   The component determination unit 1321 determines that the component related to the acquisition request is an additional component when the generated file of the component is stored in the data item “file” of the component information. On the other hand, when the generated file of the component is not stored in the data item “file” of the component information, the component determination unit 1321 determines that the component related to the acquisition request is the existing component.

本実施形態では、コンポーネント情報テーブル3000において、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報には、データ項目「ファイル」に、コンポーネントの生成ファイルが格納されている。したがって、コンポーネント判別部1321は、取得要求に係るコンポーネントが追加コンポーネントであると判別する。   In this embodiment, in the component information table 3000, the component information of the component name “ocrB” and the version “v2” stores the generated file of the component in the data item “file”. Therefore, the component determination unit 1321 determines that the component related to the acquisition request is an additional component.

コンポーネント判別部1321は、取得要求に係るコンポーネントが追加コンポーネントであると判別した場合、当該取得要求を追加コンポーネント生成部1323に送信する(ステップS1404)。   If the component determination unit 1321 determines that the component related to the acquisition request is an additional component, the component determination unit 1321 transmits the acquisition request to the additional component generation unit 1323 (step S1404).

次に、追加コンポーネント生成部1323は、当該取得要求を受け取ると、コンポーネント名「ocrB」、バージョン「v2」に基づき、コンポーネント情報テーブル3000からコンポーネントの生成ファイルを取得する(ステップS1405)。すなわち、追加コンポーネント生成部1323は、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報のデータ項目「ファイル」に格納されている生成ファイルを取得する。   Next, when the additional component generation unit 1323 receives the acquisition request, the additional component generation unit 1323 acquires a component generation file from the component information table 3000 based on the component name “ocrB” and the version “v2” (step S1405). That is, the additional component generation unit 1323 acquires the generated file stored in the data item “file” of the component information of the component name “ocrB” and the version “v2”.

続いて、追加コンポーネント生成部1323は、取得した生成ファイルに基づいて追加コンポーネントを生成する(ステップS1406)。すなわち、追加コンポーネント生成部1323は、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報から取得した生成ファイルに基づいて、OCRBコンポーネント1332を生成する。なお、OCRBコンポーネント1332の生成は、例えば、JAR形式の生成ファイルを実行して、コンポーネント共通I/F1330に定義されたコンポーネントを生成するためのAPIを用いて行うことができる。   Subsequently, the additional component generation unit 1323 generates an additional component based on the acquired generated file (step S1406). That is, the additional component generation unit 1323 generates the OCRB component 1332 based on the generation file acquired from the component information of the component name “ocrB” and version “v2”. The generation of the OCRB component 1332 can be performed, for example, using an API for generating a component defined in the component common I / F 1330 by executing a generation file in the JAR format.

そして、追加コンポーネント生成部1323は、OCRBコンポーネント1332が生成されると、OCRBコンポーネント1332をフロー実行部131に返信する。これは、例えば、追加コンポーネント生成部1323は、OCRBコンポーネント1332が展開されたメモリ(例えばRAM14)上のアドレスを、フロー実行部131に返信すれば良い。   Then, when the OCRB component 1332 is generated, the additional component generation unit 1323 returns the OCRB component 1332 to the flow execution unit 131. For example, the additional component generation unit 1323 may return the address on the memory (for example, the RAM 14) where the OCRB component 1332 is expanded to the flow execution unit 131.

次に、フロー実行部131は、データを指定して、生成されたOCRBコンポーネント1332に処理の実行を要求する(ステップS1407)。なお、ここで指定されるデータは、データ型が「InputStream」としてブラウザ210から渡される電子ファイルである。   Next, the flow execution unit 131 designates the data and requests the generated OCRB component 1332 to execute the process (step S1407). The data specified here is an electronic file passed from the browser 210 as the data type “InputStream”.

すなわち、フロー実行部131は、ブラウザ210からデータ型「InputStream」として渡される電子ファイルを、単に「データ」として(データ型を意識することなく)、OCRBコンポーネント1332に渡して処理の実行を要求する。図14では、このようにデータ型を意識することなく渡される電子ファイル等を、単に「データ」と表す。   That is, the flow execution unit 131 transfers the electronic file passed as the data type “InputStream” from the browser 210 as “data” (without being aware of the data type) to the OCRB component 1332 to request execution of the process. . In FIG. 14, an electronic file or the like passed without being aware of the data type is simply referred to as “data”.

次に、OCRBコンポーネント1332は、データが指定された処理の実行要求を受け取ると、データ型の型変換を型変換管理部134に要求する(ステップS1408)。ここで、当該型変換要求には、データと、OCRBコンポーネント1332が扱うことができるデータ型を示す「LocalFilePath」の指定とが含まれる。   Next, when the OCRB component 1332 receives an execution request for processing for which data is designated, the OCRB component 1332 requests type conversion management unit 134 for data type conversion (step S1408). Here, the type conversion request includes data and designation of “LocalFilePath” indicating a data type that the OCRB component 1332 can handle.

型変換管理部134は、型変換要求を受け取ると、当該型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致するか否かをチェックする(ステップS1409)。ここでは、受け取った型変換要求に含まれるデータのデータ型は「InputStream」である一方、指定されたデータ型は「LocalFilePath」であるから、一致しないものと判断される。   When receiving the type conversion request, the type conversion management unit 134 checks whether the data type of the data included in the type conversion request matches the designated data type (step S1409). Here, since the data type of the data included in the received type conversion request is “InputStream”, and the designated data type is “LocalFilePath”, it is determined that they do not match.

すると、型変換管理部134は、型変換テーブル4000を参照し、「InputStream」を「LocalFilePath」に変換するための型変換を特定して(ここでは、第1の型変換1351が特定される)、当該特定された型変換を生成する(ステップS1410)。   Then, the type conversion management unit 134 refers to the type conversion table 4000 and specifies type conversion for converting “InputStream” to “LocalFilePath” (here, the first type conversion 1351 is specified). , And generates the identified type conversion (step S1410).

次に、型変換管理部134は、生成された第1の型変換1351に対して、データを指定して型変換処理の実行を要求する(ステップS1411)。すると、第1の型変換1351は、指定されたデータのデータ型を「InputStream」から「LocalFilePath」に変換して(ステップS1412)、当該変換後のデータを型変換管理部134に返信する。そして、型変換管理部134は、型変換後のデータをOCRBコンポーネント1332に返信する(ステップS1413)。   Next, the type conversion management unit 134 requests the generated first type conversion 1351 to execute the type conversion process by designating data (step S1411). Then, the first type conversion 1351 converts the data type of the designated data from “InputStream” to “LocalFilePath” (step S1412), and sends the converted data to the type conversion management unit 134. Then, the type conversion management unit 134 sends the data after type conversion back to the OCRB component 1332 (step S1413).

OCRBコンポーネント1332は、型変換後のデータを受け取ると、処理を実行する(ステップS1414)。すなわち、データ型「LocalFilePath」のデータ(つまり、パス又はアドレス)により示される電子ファイルに対して、OCR処理を実行する。より具体的には、OCRBコンポーネント1332は、ドキュメントサービス部150のOCR処理151に処理を要求し、OCR処理151が当該電子ファイルに対して処理を実行する。   Upon receiving the data after type conversion, the OCRB component 1332 executes processing (step S1414). That is, the OCR processing is performed on the electronic file indicated by the data of the data type “LocalFilePath” (that is, the path or the address). More specifically, the OCRB component 1332 requests processing to the OCR processing 151 of the document service unit 150, and the OCR processing 151 executes processing on the electronic file.

そして、OCRBコンポーネント1332は、処理の実行が完了すると、データをフロー実行部131に返信する。なお、ここで返信されるデータは、OCR処理後の電子ファイルを示すパス又はアドレスである(すなわち、返信されるデータのデータ型は「LocalFilePath」である。)。   Then, when the execution of the process is completed, the OCRB component 1332 sends data back to the flow execution unit 131. The data to be returned here is a path or an address indicating the electronic file after the OCR processing (that is, the data type of the data to be returned is “Local File Path”).

次に、フロー実行部131は、取得した処理内容1300に従ってコンポーネントの取得を、コンポーネント管理部132に要求する(ステップS1415)。より具体的には、フロー実行部131は、図8に示す処理内容1300の処理定義部1302の次の処理定義部1303の記述に基づいて、コンポーネント名「uploadA」、バージョン「v1」のコンポーネントの取得を、コンポーネント管理部132に要求する。   Next, the flow execution unit 131 requests the component management unit 132 to acquire a component according to the acquired processing content 1300 (step S1415). More specifically, based on the description of the process definition unit 1303 following the process definition unit 1302 of the process content 1300 shown in FIG. The component management unit 132 is requested to acquire.

コンポーネント管理部132は、コンポーネントの取得要求を受け取ると、コンポーネント判別部1321により、当該取得要求に係るコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを判別する(ステップS1416)。すなわち、コンポーネント判別部1321は、コンポーネント情報テーブル3000を参照し、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されているか否かを判別する。   When the component management unit 132 receives the component acquisition request, the component determination unit 1321 determines whether the component related to the acquisition request is an existing component or an additional component (step S1416). That is, the component determination unit 1321 refers to the component information table 3000 and determines whether or not the generated file of the component is stored in the data item “file” of the component information of the component name “uploadA” and version “v1”. Do.

コンポーネント判別部1321は、コンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されている場合、取得要求に係るコンポーネントは追加コンポーネントであると判別する。一方、コンポーネント判別部1321は、コンポーネント情報のデータ項目「ファイル」に、コンポーネントの生成ファイルが格納されていない場合、取得要求に係るコンポーネントは既存コンポーネントであると判別する。   The component determination unit 1321 determines that the component related to the acquisition request is an additional component when the generated file of the component is stored in the data item “file” of the component information. On the other hand, when the generated file of the component is not stored in the data item “file” of the component information, the component determination unit 1321 determines that the component related to the acquisition request is the existing component.

本実施形態では、コンポーネント情報テーブル3000において、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報には、データ項目「ファイル」に、コンポーネントの生成ファイルが格納されていない。したがって、コンポーネント判別部1321は、取得要求に係るコンポーネントが既存コンポーネントであると判別する。   In the present embodiment, in the component information table 3000, the component information of the component name “uploadA” and version “v1” does not store the generated file of the component in the data item “file”. Therefore, the component determination unit 1321 determines that the component related to the acquisition request is an existing component.

コンポーネント判別部1321は、取得要求に係るコンポーネントが既存コンポーネントであると判別した場合、当該取得要求を既存コンポーネント生成部1322に送信する(ステップS1417)。   If the component determination unit 1321 determines that the component related to the acquisition request is an existing component, the component determination unit 1321 transmits the acquisition request to the existing component generation unit 1322 (step S1417).

次に、既存コンポーネント生成部1322は、コンポーネントの取得要求を受け取ると、当該取得要求に係る既存コンポーネントを生成する(ステップS1418)。すなわち、既存コンポーネント生成部1322は、コンポーネント名「uploadA」、バージョン「v1」に基づいて、配信Aコンポーネント1333を生成する。なお、配信Aコンポーネント1333の生成は、コンポーネント共通I/F1330に定義されたコンポーネントを生成するためのAPIを用いて行うことができる。   Next, upon receiving the component acquisition request, the existing component generation unit 1322 generates an existing component related to the acquisition request (step S1418). That is, the existing component generation unit 1322 generates the distribution A component 1333 based on the component name “uploadA” and the version “v1”. The distribution A component 1333 can be generated using an API for generating a component defined in the component common I / F 1330.

そして、既存コンポーネント生成部1322は、配信Aコンポーネント1333が生成されると、配信Aコンポーネント1333をフロー実行部131に返信する。これは、例えば、既存コンポーネント生成部1322は、配信Aコンポーネント1333が展開されたメモリ(例えばRAM14)上のアドレスを、フロー実行部131に返信すれば良い。   Then, when the distribution A component 1333 is generated, the existing component generation unit 1322 returns the distribution A component 1333 to the flow execution unit 131. For example, the existing component generation unit 1322 may return the address on the memory (for example, the RAM 14) in which the distribution A component 1333 is expanded to the flow execution unit 131.

次に、フロー実行部131は、データを指定して、生成された配信Aコンポーネント1333に処理の実行を要求する(ステップS1419)。なお、ここで指定されるデータは、データ型が「LocalFilePath」としてOCRBコンポーネント1332から返信されたOCR処理後の電子ファイルである。   Next, the flow execution unit 131 designates data, and requests the generated distribution A component 1333 to execute processing (step S1419). The data specified here is an electronic file after the OCR processing, which is returned from the OCRB component 1332 as a data type of “Local File Path”.

次に、配信Aコンポーネント1333は、データが指定された処理の実行要求を受け取ると、データ型の型変換を型変換管理部134に要求する(ステップS1420)。ここで、当該型変換要求には、データと、配信Aコンポーネント1333が扱うことができるデータ型を示す「LocalFilePath」の指定とが含まれる。   Next, when the distribution A component 1333 receives an execution request for processing for which data is designated, the distribution A component 1333 requests type conversion management unit 134 for data type conversion (step S1420). Here, the type conversion request includes data and designation of “LocalFilePath” indicating a data type that can be handled by the distribution A component 1333.

型変換管理部134は、型変換要求を受け取ると、当該型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致するか否かをチェックする(ステップS1421)。ここでは、受け取った型変換要求に含まれるデータのデータ型は「LocalFilePath」であり、指定されたデータ型も「LocalFilePath」であるから、一致するものと判断される。   When receiving the type conversion request, the type conversion management unit 134 checks whether the data type of the data included in the type conversion request matches the designated data type (step S 1421). Here, since the data type of the data included in the received type conversion request is “Local File Path” and the designated data type is also “Local File Path”, it is determined that they match.

そして、型変換管理部134は、型変換要求に含まれていたデータを、そのまま配信Aコンポーネント1333に送信する(ステップS1422)。このように、データ型チェック(ステップS1421の処理)で両者のデータ型が一致する場合には、型変換管理部134は型変換の生成を行わない。   Then, the type conversion management unit 134 transmits the data included in the type conversion request as it is to the distribution A component 1333 (step S1422). As described above, when the data types of the two coincide with each other in the data type check (processing of step S1421), the type conversion management unit 134 does not generate the type conversion.

配信Aコンポーネント1333は、型変換管理部134からデータを受け取ると、処理を実行する(ステップS1423)。   When the distribution A component 1333 receives the data from the type conversion management unit 134, the distribution A component 1333 executes a process (step S1423).

すなわち、配信Aコンポーネント1333は、ストレージサービスA連携部160のファイル処理部170に対して、共通I/F171として定義されているファイル保存のAPIを用いて、データの配信実行を要求する。より具体的には、配信Aコンポーネント1333は、ストレージサービスA連携部160のファイル処理部170に対して、図5(a)に示すAPIとして「service-a/process/folder」を用いてデータの配信実行を要求する。これにより、ストレージサービスAのフォルダ「FolderB」に、ファイル名「test」の電子ファイル(スキャンにより生成された電子ファイルに対してOCR処理した電子ファイル)が保存される。 That is, the distribution A component 1333, the file processing unit 170 1 of the Storage Service A linkage unit 160 1, using the API of the file storage that is defined as a common I / F171 1, requesting delivery execution data . More particularly, the distribution A component 1333, the file processing unit 170 1 of the Storage Service A linkage unit 160 1, using a "service-a / process / folder" as an API shown in FIG. 5 (a) Request delivery of data. As a result, an electronic file with the file name “test” (an electronic file obtained by performing an OCR process on an electronic file generated by scanning) is stored in the folder “Folder B” of the storage service A.

そして、配信Aコンポーネント1333は、処理の実行が完了すると、データをフロー実行部131に返信する。なお、ここで返信されるデータは、例えば、ストレージサービスAに対して電子ファイルの配信が正常に行われたことを示す処理結果である。これにより、本実施形態に係るサービス提供システム10において、処理内容1300に基づく、ストレージサービスAと連携した一連の処理の実行が完了する。   Then, when the execution of the processing is completed, the distribution A component 1333 sends data back to the flow execution unit 131. The data returned here is, for example, a processing result indicating that the distribution of the electronic file to the storage service A has been normally performed. As a result, in the service providing system 10 according to the present embodiment, the execution of a series of processes linked with the storage service A based on the process content 1300 is completed.

以上のように、本実施形態に係るサービス提供システム10では、サービスを実現するための一連の処理に含まれる一の処理を実行するコンポーネントが、既存コンポーネント又は追加コンポーネントのいずれであるかを判別する。そして、本実施形態に係るサービス提供システム10では、判別結果に応じて、既存コンポーネント又は追加コンポーネントを生成する。   As described above, in the service providing system 10 according to the present embodiment, it is determined whether the component that executes one process included in the series of processes for realizing the service is either an existing component or an additional component. . Then, in the service providing system 10 according to the present embodiment, the existing component or the additional component is generated according to the determination result.

このように、本実施形態に係るサービス提供システム10では、例えばJAR形式等で開発や配布等される様々なコンポーネントを利用することができる。このため、例えば、アプリ情報1000の開発者等は、追加コンポーネントも含めた様々なコンポーネントにより実行される処理で構成される一連の処理の内容を処理内容として記述することができる。したがって、本実施形態に係るサービス提供システム10では、追加コンポーネントにより実行される処理を含む一連の処理で実現される多様なサービスを提供することができるようになる。   As described above, in the service providing system 10 according to the present embodiment, various components developed or distributed in, for example, a JAR format can be used. Therefore, for example, a developer or the like of the application information 1000 can describe, as processing content, the content of a series of processing configured by processing executed by various components including additional components. Therefore, in the service providing system 10 according to the present embodiment, it is possible to provide various services realized by a series of processes including the process executed by the additional component.

≪コンポーネントの追加、更新、及び削除処理≫
次に、本実施形態に係るサービス提供システム10に対して追加コンポーネントを追加する場合や追加コンポーネントを更新する場合、追加コンポーネントを削除する場合の処理について、図15を参照しながら説明する。図15は、第一の実施形態に係るコンポーネントの追加、更新、及び削除処理の一例を示すシーケンス図である。
<< Adding, Updating, and Deleting Components >>
Next, processing when adding an additional component to the service providing system 10 according to the present embodiment or when adding an additional component will be described with reference to FIG. 15 when deleting an additional component. FIG. 15 is a sequence diagram showing an example of the process of adding, updating and deleting components according to the first embodiment.

まず、コンポーネントの開発者等のユーザは、PC端末30のブラウザ310により、コンポーネント編集画面の表示操作を行う。すると、ブラウザ310は、当該表示操作を受け付けて、例えば図16(a)に示すコンポーネント編集画面5000を、表示装置12に表示させる(ステップS1501)。   First, a user such as a component developer performs a display operation of the component editing screen using the browser 310 of the PC terminal 30. Then, the browser 310 receives the display operation and causes the display device 12 to display, for example, a component editing screen 5000 shown in FIG. 16A (step S1501).

図16(a)に示すコンポーネント編集画面5000は、追加コンポーネントの追加(登録)、更新、及び削除を行うための画面である。コンポーネント編集画面5000には、新たなコンポーネントをコンポーネント情報テーブル3000に登録するための追加ボタン5010、登録されている追加コンポーネントを更新するための更新ボタン5020、削除するための削除ボタン5030が含まれる。   The component editing screen 5000 shown in FIG. 16A is a screen for performing addition (registration), update, and deletion of an additional component. The component editing screen 5000 includes an add button 5010 for registering a new component in the component information table 3000, an update button 5020 for updating the registered additional component, and a delete button 5030 for deleting.

コンポーネント編集画面5000において、ユーザにより追加ボタン5010が選択された場合、ブラウザ310は、当該操作を受け付けて、例えば図16(b)に示すコンポーネント追加画面5100を表示させる(ステップS1502)。   When the add button 5010 is selected by the user on the component editing screen 5000, the browser 310 receives the operation and displays, for example, a component adding screen 5100 shown in FIG. 16B (step S1502).

図16(b)に示すコンポーネント追加画面5100は、コンポーネントを追加(登録)するための画面であり、コンポーネント名欄5110、ファイル欄5120、参照ボタン5130、及び登録ボタン5140が含まれる。   The component addition screen 5100 shown in FIG. 16B is a screen for adding (registering) a component, and includes a component name field 5110, a file field 5120, a reference button 5130, and a registration button 5140.

ユーザは、コンポーネント名欄5110に登録する追加コンポーネントのコンポーネント名を入力し、ファイル欄5120に追加コンポーネントの生成ファイルを指定した上で、登録ボタン5140を押下して、追加コンポーネントの登録操作を行う。すると、ブラウザ310は、当該登録操作を受け付ける(ステップS1503)。なお、ユーザは、参照ボタン5130を押下して生成ファイルの格納先の一覧を表示した上で、当該一覧から所望の生成ファイルを選択することで、ファイル欄5120に生成ファイルを指定しても良い。   The user inputs the component name of the additional component to be registered in the component name column 5110, designates the generated file of the additional component in the file column 5120, and presses the registration button 5140 to perform the registration operation of the additional component. Then, the browser 310 receives the registration operation (step S1503). Note that the user may designate a generated file in the file column 5120 by pressing the reference button 5130 to display a list of storage destinations of generated files and selecting a desired generated file from the list. .

ブラウザ310は、追加コンポーネントの登録操作を受け付けると、コンポーネントの登録を、コンポーネント管理部132に要求する(ステップS1504)。なお、コンポーネントの登録要求には、コンポーネント名欄5110に指定されたコンポーネント名と、ファイル欄5120に指定された生成ファイルとが含まれる。   When the browser 310 receives the registration operation of the additional component, the browser 310 requests the component management unit 132 to register the component (step S1504). The component registration request includes the component name designated in the component name column 5110 and the generated file designated in the file column 5120.

コンポーネント管理部132は、コンポーネントの登録要求を受け取ると、コンポーネント登録部1324により、当該登録要求に含まれるコンポーネント名及び生成ファイルに基づきコンポーネント情報を作成する。そして、コンポーネント登録部1324は、作成したコンポーネント情報をコンポーネント情報テーブル3000に登録する(ステップS1504)。これにより、本実施形態に係るサービス提供システム10に追加コンポーネントが登録される。   When the component management unit 132 receives the component registration request, the component registration unit 1324 creates component information based on the component name and the generated file included in the registration request. Then, the component registration unit 1324 registers the created component information in the component information table 3000 (step S1504). Thus, the additional component is registered in the service providing system 10 according to the present embodiment.

なお、コンポーネント登録部1324は、当該登録要求に含まれるコンポーネント名と同一のコンポーネント名がコンポーネント情報テーブル3000に存在しない場合、データ項目「バージョン」に「v1」を設定してコンポーネント情報を作成する。一方、コンポーネント登録部1324は、当該登録要求に含まれるコンポーネント名と同一のコンポーネント名がコンポーネント情報テーブル3000に存在する場合、データ項目「バージョン」に最新のバージョンを付与してコンポーネント情報を作成する。   When the component name identical to the component name included in the registration request does not exist in the component information table 3000, the component registration unit 1324 sets “v1” in the data item “version” to create component information. On the other hand, when the component name identical to the component name included in the registration request exists in the component information table 3000, the component registration unit 1324 assigns the latest version to the data item “version” to create component information.

また、コンポーネント登録部1324は、当該登録要求に含まれる生成ファイルから追加コンポーネントの入力パラメータに関する情報を取得して、当該入力パラメータに関する情報を、データ項目「パラメータ」に設定してコンポーネント情報を作成する。なお、コンポーネント登録部1324は、例えばデータ形式が異なる等により、生成ファイルから入力パラメータに関する情報を取得することができない場合は、ユーザに入力パラメータに関する情報を指定させるための画面をPC端末30に表示させても良い。   Also, the component registration unit 1324 acquires information on input parameters of the additional component from the generated file included in the registration request, sets information on the input parameters in the data item “parameter”, and creates component information. . If the component registration unit 1324 can not acquire the information on the input parameter from the generated file, for example, because the data format is different, the PC terminal 30 displays a screen for allowing the user to specify the information on the input parameter. You may

コンポーネント編集画面5000において、ユーザにより、更新を所望する追加コンポーネントのコンポーネント名及びバージョンが対応付けられた更新ボタン5020が選択された場合、ブラウザ310は、当該操作を受け付ける。そして、ブラウザ310は、例えば図16(c)に示すコンポーネント更新画面5200を表示させる(ステップS1506)。   In the component editing screen 5000, when the user selects the update button 5020 in which the component name and the version of the additional component desired to be updated are associated, the browser 310 receives the operation. Then, the browser 310 displays, for example, a component update screen 5200 shown in FIG. 16C (step S1506).

図16(c)に示すコンポーネント更新画面5200は、追加コンポーネントを更新するための画面であり、ファイル欄5210、参照ボタン5220、及び更新ボタン5230が含まれる。   The component update screen 5200 shown in FIG. 16C is a screen for updating an additional component, and includes a file field 5210, a reference button 5220, and an update button 5230.

ユーザは、ファイル欄5210に生成ファイルを指定した上で、更新ボタン5230を押下して、追加コンポーネントの更新操作を行う。すると、ブラウザ310は、当該更新操作を受け付ける(ステップS1507)。なお、ユーザは、参照ボタン5220を押下して、生成ファイルの格納先の一覧を表示した上で、当該一覧から所望の生成ファイルを選択することで、ファイル欄5210に生成ファイルを指定しても良い。   The user designates the generated file in the file column 5210 and presses the update button 5230 to perform an update operation of the added component. Then, the browser 310 receives the update operation (step S1507). Note that even if the user presses the reference button 5220 to display a list of storage destinations of generated files, and then selects a desired generated file from the list, even if the generated file is specified in the file column 5210. good.

ブラウザ310は、追加コンポーネントの更新操作を受け付けると、コンポーネントの更新を、コンポーネント管理部132に要求する(ステップS1508)。なお、コンポーネントの更新要求には、ユーザにより選択された更新ボタン5020に対応付けられたコンポーネント名及びバージョンと、ファイル欄5210に指定された生成ファイルとが含まれる。   When the browser 310 receives the update operation of the additional component, the browser 310 requests the component management unit 132 to update the component (step S1508). The component update request includes the component name and version associated with the update button 5020 selected by the user, and the generated file specified in the file field 5210.

コンポーネント管理部132は、コンポーネントの更新要求を受け取ると、コンポーネント登録部1324により、コンポーネント情報テーブル3000に登録されているコンポーネント情報を更新する(ステップS1509)。すなわち、コンポーネント登録部1324は、当該登録要求に含まれるコンポーネント名及びバージョンに対応するコンポーネント情報のデータ項目「ファイル」を、当該登録要求に含まれる生成ファイルで上書きして更新する。これにより、本実施形態に係るサービス提供システム10に登録されている追加コンポーネントが更新される。   When the component management unit 132 receives the component update request, the component registration unit 1324 updates component information registered in the component information table 3000 (step S1509). That is, the component registration unit 1324 overwrites and updates the data item “file” of the component information corresponding to the component name and the version included in the registration request with the generated file included in the registration request. Thereby, the additional component registered in the service providing system 10 according to the present embodiment is updated.

なお、本実施形態に係るサービス提供システム10は、追加コンポーネントの更新により、アプリ情報1000に含まれる処理内容に基づく一連の処理が正常に実行することができなくなる場合、当該更新を行わないようにしても良い。又は、この場合、更新前のコンポーネント情報を残しつつ、更新後のコンポーネント情報をコンポーネント情報テーブル3000に登録するようにしても良い。   The service providing system 10 according to the present embodiment prevents the update from being performed when the series of processes based on the process content included in the application information 1000 can not be normally executed due to the update of the additional component. It is good. Alternatively, in this case, the component information after update may be registered in the component information table 3000 while leaving the component information before update.

また、本実施形態に係るサービス提供システム10は、更新対象の追加コンポーネントを利用した一連の処理が実行中である場合、当該一連の処理の実行が完了した後、更新対象の追加コンポーネントを更新すれば良い。   Further, when the series of processes using the additional component to be updated is being executed, the service providing system 10 according to the present embodiment can update the additional component to be updated after the execution of the series of processes is completed. Just do it.

コンポーネント編集画面5000において、ユーザにより、削除を所望する追加コンポーネントのコンポーネント名及びバージョンに対応付けられた削除ボタン5030が選択された場合、ブラウザ310は、当該操作を受け付ける(ステップS1510)。   When the user selects the delete button 5030 associated with the component name and version of the additional component desired to be deleted in the component editing screen 5000, the browser 310 receives the operation (step S1510).

ブラウザ310は、追加コンポーネントの削除操作を受け付けると、コンポーネントの削除を、コンポーネント管理部132に要求する(ステップS1511)。なお、コンポーネントの削除要求には、ユーザにより選択された削除ボタン5030に対応付けられたコンポーネント名及びバージョンが含まれる。   When the browser 310 receives the deletion operation of the added component, the browser 310 requests the component management unit 132 to delete the component (step S1511). The component deletion request includes the component name and the version associated with the deletion button 5030 selected by the user.

コンポーネント管理部132は、コンポーネントの削除要求を受け取ると、コンポーネント登録部1324により、コンポーネント情報テーブル3000に登録されているコンポーネント情報を削除する(ステップS1512)。すなわち、コンポーネント登録部1324は、当該削除要求に含まれるコンポーネント名及びバージョンに対応するコンポーネント情報を、コンポーネント情報テーブル3000から削除する。これにより、本実施形態に係るサービス提供システム10に登録されている追加コンポーネントが削除される。   When the component management unit 132 receives the component deletion request, the component registration unit 1324 deletes the component information registered in the component information table 3000 (step S1512). That is, the component registration unit 1324 deletes component information corresponding to the component name and version included in the deletion request from the component information table 3000. Thereby, the additional component registered in the service providing system 10 according to the present embodiment is deleted.

以上のように、本実施形態に係るサービス提供システム10では、PC端末30等から追加コンポーネントの登録を行うことができる。このため、アプリ情報1000の開発者等のユーザは、自身が開発するアプリ情報1000が利用する追加コンポーネントをサービス提供システム10に登録することができる。したがって、本実施形態に係るサービス提供システム10では、様々なサービスを提供することができるようになる。   As described above, in the service providing system 10 according to the present embodiment, the additional component can be registered from the PC terminal 30 or the like. Therefore, a user such as a developer of the application information 1000 can register, in the service providing system 10, an additional component used by the application information 1000 developed by the user. Therefore, in the service providing system 10 according to the present embodiment, various services can be provided.

また、本実施形態に係るサービス提供システム10では、登録されている追加コンポーネントを、PC端末30等から更新や削除を行うことができる。このため、アプリ情報1000の開発者等のユーザは、例えば、アプリ情報1000が利用する追加コンポーネントの更新を行うことができ、柔軟にアプリ情報1000を開発することができるようになる。   Further, in the service providing system 10 according to the present embodiment, the registered additional component can be updated or deleted from the PC terminal 30 or the like. Therefore, a user such as a developer of the application information 1000 can update, for example, an additional component used by the application information 1000, and can flexibly develop the application information 1000.

さらに、本実施形態に係るサービス提供システム10では、例えばJAR形式等で開発や配布等される生成ファイルを登録することで、追加コンポーネントを利用することができるようになる。このため、本実施形態に係るサービス提供システム10では、既存コンポーネントに影響を与えることなく、追加コンポーネントの登録、更新、削除を行うことができる。すなわち、本実施形態に係るサービス提供システム10では、当該サービス提供システム10を停止等させる必要なく、動的に追加コンポーネントの登録、更新、削除を行うことができる。   Furthermore, in the service providing system 10 according to the present embodiment, additional components can be used by registering a generated file to be developed or distributed in, for example, a JAR format. Thus, in the service providing system 10 according to the present embodiment, registration, update, and deletion of additional components can be performed without affecting existing components. That is, in the service providing system 10 according to the present embodiment, it is possible to dynamically register, update, and delete additional components without having to stop the service providing system 10 or the like.

[第二の実施形態]
次に、第二の実施形態に係る情報処理システム1について説明する。第二の実施形態では、フロー実行処理において、実行されるコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを、第一の実施形態と異なる方法で判別する。なお、以降では、第一の実施形態と実質的に同一の機能を有する箇所及び同一の処理を行う箇所については、第一の実施形態と同一の符号を用いて、その説明を省略する。
Second Embodiment
Next, an information processing system 1 according to a second embodiment will be described. In the second embodiment, in the flow execution process, it is determined whether the component to be executed is an existing component or an additional component in a method different from the first embodiment. In the following, the same reference numerals as in the first embodiment are used for the portions having substantially the same functions as the first embodiment and the portions in which the same processing is performed, and the description thereof will be omitted.

<ソフトウェア構成>
本実施形態に係る情報処理システム1に含まれるサービス提供システム10のロジック処理部130の処理ブロックについて、図17を参照しながら説明する。図17は、第二の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。
<Software configuration>
Processing blocks of the logic processing unit 130 of the service providing system 10 included in the information processing system 1 according to the present embodiment will be described with reference to FIG. FIG. 17 is a diagram showing a processing block of an example of the logic processing unit according to the second embodiment.

本実施形態に係るロジック処理部130のコンポーネント管理部132は、コンポーネント判別部1321Aを有する。また、本実施形態に係るロジック処理部130は、コンポーネント情報テーブル3000Aを利用する。   The component management unit 132 of the logic processing unit 130 according to the present embodiment includes a component determination unit 1321A. Also, the logic processing unit 130 according to the present embodiment uses the component information table 3000A.

コンポーネント判別部1321Aは、コンポーネントの取得要求に応じて、コンポーネント情報テーブル3000Aを参照し、当該取得要求に係るコンポーネントが、既存コンポーネント又は追加コンポーネントのいずれであるかを判別する。   The component determination unit 1321A refers to the component information table 3000A in response to the component acquisition request, and determines whether the component related to the acquisition request is an existing component or an additional component.

ここで、コンポーネント情報テーブル3000Aについて、図18を参照しながら説明する。図18は、第二の実施形態に係るコンポーネント情報テーブルの一例を示す図である。   Here, the component information table 3000A will be described with reference to FIG. FIG. 18 is a diagram showing an example of a component information table according to the second embodiment.

図18に示すコンポーネント情報テーブル3000Aは、データ項目として、さらに、コンポーネント区分を有する。コンポーネント区分は、コンポーネント情報が、既存コンポーネントのコンポーネント情報又は追加コンポーネントのコンポーネント情報のいずれであるかを示す区分である。したがって、本実施形態に係るコンポーネント判別部1321Aは、コンポーネント情報のコンポーネント区分を参照することで、コンポーネントの取得要求に係るコンポーネントが、既存コンポーネント又は追加コンポーネントのいずれであるかを判別することができる。   The component information table 3000A shown in FIG. 18 further has component sections as data items. The component classification is a classification indicating whether the component information is component information of an existing component or component information of an additional component. Therefore, the component determination unit 1321A according to the present embodiment can determine whether the component related to the component acquisition request is an existing component or an additional component by referring to the component classification of the component information.

<処理の詳細>
次に、本実施形態に係る情報処理システム1の処理の詳細について説明する。
<Details of processing>
Next, details of processing of the information processing system 1 according to the present embodiment will be described.

≪フロー実行処理≫
以降では、本実施形態に係るフロー実行処理について、図19を参照しながら説明する。図19は、第二の実施形態に係るフロー実行処理の一例を示すシーケンス図である。なお、第一の実施形態に係るフロー実行処理と同様の処理を行う箇所については、その説明を省略する。
<< flow execution processing >>
Hereinafter, the flow execution process according to the present embodiment will be described with reference to FIG. FIG. 19 is a sequence diagram showing an example of flow execution processing according to the second embodiment. In addition, the description is abbreviate | omitted about the location which performs the process similar to the flow execution process which concerns on 1st embodiment.

コンポーネント管理部132は、コンポーネントの取得要求を受け取ると、コンポーネント判別部1321Aにより、当該取得要求に係るコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを判別する(ステップS1901)。すなわち、コンポーネント判別部1321Aは、コンポーネント情報テーブル3000Aを参照し、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報のデータ項目「コンポーネント区分」が、「既存」又は「追加」のいずれであるかを判別する。   When the component management unit 132 receives the component acquisition request, the component determination unit 1321A determines whether the component related to the acquisition request is an existing component or an additional component (step S1901). That is, the component determination unit 1321A refers to the component information table 3000A and determines whether the data item "component classification" of component information of the component name "ocrB" and version "v2" is "existing" or "addition". To determine

コンポーネント判別部1321Aは、コンポーネント情報のデータ項目「コンポーネント区分」が「追加」である場合、取得要求に係るコンポーネントは追加コンポーネントであると判別する。一方、コンポーネント判別部1321Aは、コンポーネント情報のデータ項目「コンポーネント区分」が「既存」である場合、取得要求に係るコンポーネントは既存コンポーネントであると判別する。   When the data item “component classification” of the component information is “addition”, the component determination unit 1321A determines that the component related to the acquisition request is an additional component. On the other hand, when the data item “component classification” of the component information is “existing”, the component determination unit 1321A determines that the component related to the acquisition request is the existing component.

本実施形態では、コンポーネント情報テーブル3000Aにおいて、コンポーネント名「ocrB」、バージョン「v2」のコンポーネント情報は、データ項目「コンポーネント区分」が「追加」である。したがって、コンポーネント判別部1321Aは、取得要求に係るコンポーネントが追加コンポーネントであると判別する。   In the present embodiment, in the component information table 3000A, in the component information of the component name “ocrB” and the version “v2”, the data item “component classification” is “addition”. Therefore, the component determination unit 1321A determines that the component related to the acquisition request is an additional component.

コンポーネント管理部132は、コンポーネントの取得要求を受け取ると、コンポーネント判別部1321Aにより、当該取得要求に係るコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを判別する(ステップS1902)。すなわち、コンポーネント判別部1321Aは、コンポーネント情報テーブル3000Aを参照し、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報のデータ項目「コンポーネント区分」が、「既存」又は「追加」のいずれであるかを判別する。   When the component management unit 132 receives the component acquisition request, the component determination unit 1321A determines whether the component related to the acquisition request is an existing component or an additional component (step S1902). That is, the component determination unit 1321A refers to the component information table 3000A and determines whether the component item “component classification” of the component information of the component name “uploadA” and version “v1” is “existing” or “addition”. To determine

本実施形態では、コンポーネント情報テーブル3000Aにおいて、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報は、データ項目「コンポーネント区分」が「既存」である。したがって、コンポーネント判別部1321Aは、取得要求に係るコンポーネントが既存コンポーネントであると判別する。   In the present embodiment, in the component information table 3000A, in the component information of the component name “uploadA” and version “v1”, the data item “component classification” is “existing”. Therefore, the component determination unit 1321A determines that the component related to the acquisition request is an existing component.

以上のように、本実施形態に係るサービス提供システム10では、コンポーネント情報のデータ項目「コンポーネント区分」を参照することで、取得要求に係るコンポーネントが既存コンポーネント又は追加コンポーネントのいずれであるかを判別する。これにより、本実施形態に係るサービス提供システム10では、既存コンポーネント又は追加コンポーネントのいずれであるかの判別を、より簡易に行うことができる。   As described above, the service providing system 10 according to the present embodiment determines whether the component related to the acquisition request is the existing component or the additional component by referring to the data item “component classification” of the component information. . Thereby, in the service providing system 10 according to the present embodiment, it is possible to more easily determine whether the component is an existing component or an additional component.

[第三の実施形態]
次に、第三の実施形態に係る情報処理システム1について説明する。第三の実施形態では、フロー実行処理において、既存コンポーネントも生成ファイルに基づいて生成する。なお、以降では、第二の実施形態と実質的に同一の機能を有する箇所及び同一の処理を行う箇所については、第二の実施形態と同一の符号を用いて、その説明を省略する。
Third Embodiment
Next, an information processing system 1 according to the third embodiment will be described. In the third embodiment, in the flow execution process, an existing component is also generated based on the generated file. In the following, the same reference numerals as those in the second embodiment are used for the portions having substantially the same functions as those in the second embodiment and the portions in which the same processing is performed, and the description thereof will be omitted.

<ソフトウェア構成>
本実施形態に係る情報処理システム1に含まれるサービス提供システム10のロジック処理部130の処理ブロックについて、図20を参照しながら説明する。図20は、第三の実施形態に係るロジック処理部の一例の処理ブロックを示す図である。
<Software configuration>
Processing blocks of the logic processing unit 130 of the service providing system 10 included in the information processing system 1 according to the present embodiment will be described with reference to FIG. FIG. 20 is a diagram showing a processing block of an example of the logic processing unit according to the third embodiment.

本実施形態に係るロジック処理部130のコンポーネント管理部132は、既存コンポーネント生成部1322Aを有する。また、本実施形態に係るロジック処理部130は、コンポーネント情報テーブル3000Bを利用する。   The component management unit 132 of the logic processing unit 130 according to the present embodiment includes an existing component generation unit 1322A. Also, the logic processing unit 130 according to the present embodiment uses the component information table 3000B.

既存コンポーネント生成部1322Aは、コンポーネント判別部1321Aによりコンポーネントの取得要求に係るコンポーネントが既存コンポーネントであると判別された場合、当該取得要求に係る既存コンポーネントを生成する。このとき、既存コンポーネント生成部1322Aは、コンポーネント情報テーブル3000Bから既存コンポーネントの生成ファイルを取得し、当該取得した生成ファイルに基づいて既存コンポーネントを生成する。   When the component determination unit 1321A determines that the component related to the component acquisition request is the existing component, the existing component generation unit 1322A generates the existing component related to the acquisition request. At this time, the existing component generation unit 1322A acquires the generated file of the existing component from the component information table 3000B, and generates the existing component based on the acquired generated file.

ここで、コンポーネント情報テーブル3000Bについて、図21を参照しながら説明する。図21は、第三の実施形態に係るコンポーネント情報テーブルの一例を示す図である。   Here, the component information table 3000B will be described with reference to FIG. FIG. 21 is a diagram showing an example of a component information table according to the third embodiment.

図21に示すコンポーネント情報テーブル3000Bは、既存コンポーネントのコンポーネント情報のデータ項目「ファイル」に、生成ファイルが格納されている。このように、本実施形態に係るコンポーネント情報テーブル3000Bは、既存コンポーネントの生成ファイルも管理している。   In the component information table 3000B shown in FIG. 21, the generated file is stored in the data item "file" of the component information of the existing component. Thus, the component information table 3000B according to the present embodiment also manages the generated file of the existing component.

<処理の詳細>
次に、本実施形態に係る情報処理システム1の処理の詳細について説明する。
<Details of processing>
Next, details of processing of the information processing system 1 according to the present embodiment will be described.

≪フロー実行処理≫
以降では、本実施形態に係るフロー実行処理について、図22を参照しながら説明する。図22は、第三の実施形態に係るフロー実行処理の一例を示すシーケンス図である。なお、第二の実施形態に係るフロー実行処理と同様の処理を行う箇所については、その説明を省略する。
<< flow execution processing >>
Hereinafter, the flow execution process according to the present embodiment will be described with reference to FIG. FIG. 22 is a sequence diagram showing an example of flow execution processing according to the third embodiment. In addition, the description is abbreviate | omitted about the location which performs the process similar to the flow execution process which concerns on 2nd embodiment.

既存コンポーネント生成部1322Aは、コンポーネントの取得要求を受け取ると、コンポーネント名「uploadA」、バージョン「v1」に基づき、コンポーネント情報テーブル3000Bからコンポーネントの生成ファイルを取得する(ステップS2201)。すなわち、既存コンポーネント生成部1322Aは、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報のデータ項目「ファイル」に格納されている生成ファイルを取得する。   When the existing component generation unit 1322A receives the component acquisition request, the existing component generation unit 1322A acquires a component generation file from the component information table 3000B based on the component name "uploadA" and the version "v1" (step S2201). That is, the existing component generation unit 1322A acquires the generated file stored in the data item “file” of the component information of the component name “uploadA” and version “v1”.

次に、既存コンポーネント生成部1322Aは、取得した生成ファイルに基づいて既存コンポーネントを生成する(ステップS2202)。すなわち、既存コンポーネント生成部1322Aは、コンポーネント名「uploadA」、バージョン「v1」のコンポーネント情報から取得した生成ファイルに基づいて、配信Aコンポーネント1333を生成する。なお、配信Aコンポーネント1333の生成は、例えば、JAR形式の生成ファイルを実行して、コンポーネント共通I/F1330に定義されたコンポーネントを生成するためのAPIを用いて行うことができる。   Next, the existing component generation unit 1322A generates an existing component based on the acquired generated file (step S2202). That is, the existing component generation unit 1322A generates the distribution A component 1333 based on the generation file acquired from the component information of the component name “uploadA” and version “v1”. The distribution A component 1333 can be generated, for example, using an API for generating a component defined in the component common I / F 1330 by executing a generation file in the JAR format.

そして、既存コンポーネント生成部1322Aは、配信Aコンポーネント1333が生成されると、配信Aコンポーネント1333をフロー実行部131に返信する。これは、例えば、既存コンポーネント生成部1322Aは、配信Aコンポーネント1333が展開されたメモリ(例えばRAM14)上のアドレスを、フロー実行部131に返信すれば良い。   Then, when the distribution A component 1333 is generated, the existing component generation unit 1322A returns the distribution A component 1333 to the flow execution unit 131. For example, the existing component generation unit 1322A may return, to the flow execution unit 131, the address on the memory (for example, the RAM 14) in which the distribution A component 1333 is expanded.

以上のように、本実施形態に係るサービス提供システム10では、コンポーネント情報テーブル3000Bに格納された生成ファイルに基づいて、既存コンポーネントの生成を行う。これにより、本実施形態に係るサービス提供システム10では、既存コンポーネントと追加コンポーネントを同様に管理することができる。   As described above, in the service providing system 10 according to the present embodiment, the existing component is generated based on the generation file stored in the component information table 3000B. Thereby, in the service providing system 10 according to the present embodiment, the existing component and the additional component can be managed in the same manner.

本発明は、具体的に開示された上記の実施形態に限定されるものではなく、特許請求の範囲から逸脱することなく、種々の変形や変更が可能である。   The present invention is not limited to the above specifically disclosed embodiments, and various modifications and changes are possible without departing from the scope of the claims.

1 情報処理システム
10 サービス提供システム
20 画像形成装置
30 PC端末
40 外部ストレージシステム
110 サービス処理部
120 アプリ管理部
130 ロジック処理部
131 フロー実行部
132 コンポーネント管理部
133 コンポーネント群
134 型変換管理部
135 型変換群
140 データI/F部
150 ドキュメントサービス部
151 OCR処理
160 ストレージサービス連携部
170 ファイル処理部
180 データ処理部
190 アプリ情報記憶部
1000 アプリ情報
1321 コンポーネント判別部
1322 既存コンポーネント生成部
1323 追加コンポーネント生成部
1324 コンポーネント登録部
3000 コンポーネント情報テーブル
4000 型変換テーブル
Reference Signs List 1 information processing system 10 service providing system 20 image forming apparatus 30 PC terminal 40 external storage system 110 service processing unit 120 application management unit 130 logic processing unit 131 flow execution unit 132 component management unit 133 component group 134 type conversion management unit 135 type conversion Group 140 Data I / F unit 150 Document service unit 151 OCR processing 160 Storage service cooperation unit 170 File processing unit 180 Data processing unit 190 Application information storage unit 1000 Application information 1321 Component discrimination unit 1322 Existing component generation unit 1323 Additional component generation unit 1324 Component registration unit 3000 Component information table 4000 type conversion table

特開2014−032659号公報JP, 2014-032659, A

Claims (10)

1以上の情報処理装置が含まれる情報処理システムであって、
電子データを用いた一連の処理を、該一連の処理それぞれを実行するコンポーネントを組み合わせて実行するアプリケーション毎に、該アプリケーションを識別するアプリ識別情報と、前記一連の処理に関する情報と、前記一連の処理に用いる前記電子データを指定させる画面の画面情報と、を関連付けて記憶する第1の記憶手段と、
前記コンポーネントに関する情報を記憶する第2の記憶手段と、
前記情報処理システムに接続される1以上の機器のうちの一の機器から前記アプリ識別情報を含む第1の要求を受け付けると、該第1の要求に含まれる該アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記画面情報を、要求元の前記一の機器に送信する送信手段と、
前記送信手段により送信された前記画面情報に基づき前記一の機器に表示された画面を介してユーザにより指定された電子データに関する情報を含む第2の要求を前記一の機器から受け付けると、前記アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記一連の処理に関する情報に基づく一連の処理を、前記第2の要求に含まれる前記電子データに関する情報により指定される電子データを用いて実行する処理実行手段と
を有し、
前記コンポーネントには、ユーザにより登録された第1のコンポーネントと、前記情報処理システムに予め組み込まれている第2のコンポーネントとが含まれ、
前記処理実行手段は、
前記一連の処理のそれぞれの処理毎に、該一連の処理に関する情報と前記コンポーネントに関する情報と基づき、前記第1のコンポーネント又は前記第2のコンポーネントのいずれを生成するかを判別する判別手段を有し、
前記判別手段による判別結果に応じて生成された第1のコンポーネント又は第2のコンポーネントを組み合わせて、前記電子データを用いた前記一連の処理を実行する、情報処理システム。
An information processing system including one or more information processing apparatuses, wherein
For each application that executes a series of processes using electronic data by combining components that execute the series of processes, application identification information for identifying the application, information on the series of processes, and the series of processes A first storage unit that associates and stores screen information of a screen for specifying the electronic data used for
Second storage means for storing information regarding the component;
When a first request including the application identification information is received from one of the one or more devices connected to the information processing system, the first request is associated with the application identification information included in the first request. Transmission means for transmitting the screen information stored in the one storage means to the one device of the request source;
When a second request including information related to electronic data designated by the user is received from the one device via the screen displayed on the one device based on the screen information transmitted by the transmission unit, the application A series of processes based on the information on the series of processes stored in the first storage means in association with identification information using electronic data specified by the information on the electronic data included in the second request Processing execution means for
The components include a first component registered by a user and a second component incorporated in advance in the information processing system.
The process execution means is
It has determination means for determining whether to generate the first component or the second component based on the information on the series of processes and the information on the components for each process of the series of processes. ,
An information processing system , which combines the first component or the second component generated according to the determination result by the determination means, and executes the series of processes using the electronic data .
前記判別手段は、
前記コンポーネントに関する情報に、該コンポーネントを生成するための生成ファイルが含まれる場合、前記第1のコンポーネントを生成すると判別する、請求項に記載の情報処理システム。
The judging means
The information on the component, if it contains the generated file to produce the component determines that generates the first component, the information processing system according to claim 1.
前記処理実行手段は、
前記第1のコンポーネントを生成する第1の生成手段と、
前記第2のコンポーネントを生成する第2の生成手段と、を有し、
前記判別手段により前記第1のコンポーネントを生成すると判別された場合、前記第1の生成手段により前記第1のコンポーネントを生成し、
前記判別手段により前記第2のコンポーネントを生成すると判別された場合、前記第2の生成手段により前記第2のコンポーネントを生成する、請求項に記載の情報処理システム。
The process execution means is
First generation means for generating the first component;
Second generation means for generating the second component;
When it is determined that the first component is generated by the determination unit, the first component is generated by the first generation unit;
Wherein when it is determined to generate the second component by discriminating means, for generating a second component by the second generation means, the information processing system according to claim 2.
前記第1の生成手段は、前記コンポーネントに関する情報に含まれる前記生成ファイルに基づいて、前記第1のコンポーネントを生成する、請求項に記載の情報処理システム。 The information processing system according to claim 3 , wherein the first generation unit generates the first component based on the generation file included in the information on the component. 前記処理実行手段は、
前記機器に表示された画面を介してユーザにより指定された生成ファイルを含む第3の要求を受け付けると、該第3の要求に含まれる前記生成ファイルを含むコンポーネントに関する情報を前記第2の記憶手段に記憶させて、該生成ファイルにより生成される第1のコンポーネントを登録する登録手段を有する、請求項に記載の情報処理システム。
The process execution means is
When a third request including a generation file specified by the user via a screen displayed on the device is received, the information regarding the component including the generation file included in the third request is stored in the second storage unit The information processing system according to claim 4 , further comprising: registration means for storing the first component stored by the generation file and storing the first component.
前記処理実行手段は、
電子データに対して、該電子データのデータ型を所定のデータ型に変換する型変換手段を1以上有し、
前記電子データのデータ型を前記型変換手段により該コンポーネントが処理可能なデータ型に変換した後、前記コンポーネントの処理を実行することにより、前記電子データを用いた前記一連の処理を実行する、請求項1ないしのいずれか1項に記載の情報処理システム。
The process execution means is
For electronic data, it has one or more type conversion means for converting the data type of the electronic data into a predetermined data type,
After the data type of the electronic data is converted into a data type that can be processed by the component by the type conversion means, the series of processes using the electronic data is executed by executing the process of the component. The information processing system according to any one of Items 1 to 5 .
前記コンポーネントは、外部サービスに関する処理を実行するコンポーネントを含み、
前記外部サービスに関する処理を実行するコンポーネントは、
外部サービスに対して電子データをアップロードする処理を実行するコンポーネントを少なくとも含む、請求項1ないしのいずれか1項に記載の情報処理システム。
The component includes a component that performs processing related to an external service,
The component that executes the process related to the external service is
The information processing system according to any one of claims 1 to 6 , further comprising at least a component that executes a process of uploading electronic data to an external service.
情報処理装置であって、
電子データを用いた一連の処理を、該一連の処理それぞれを実行するコンポーネントを組み合わせて実行するアプリケーション毎に、該アプリケーションを識別するアプリ識別情報と、前記一連の処理に関する情報と、前記一連の処理に用いる前記電子データを指定させる画面の画面情報と、を関連付けて記憶する第1の記憶手段と、
前記コンポーネントに関する情報を記憶する第2の記憶手段と、
前記情報処理装置に接続される1以上の機器のうちの一の機器から前記アプリ識別情報を含む第1の要求を受け付けると、該第1の要求に含まれる該アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記画面情報を、要求元の前記一の機器に送信する送信手段と、
前記送信手段により送信された前記画面情報に基づき前記一の機器に表示された画面を介してユーザにより指定された電子データに関する情報を含む第2の要求を前記一の機器から受け付けると、前記アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記一連の処理に関する情報に基づく一連の処理を、前記第2の要求に含まれる前記電子データに関する情報により指定される電子データを用いて実行する処理実行手段と
を有し、
前記コンポーネントには、ユーザにより登録された第1のコンポーネントと、前記情報処理装置に予め組み込まれている第2のコンポーネントとが含まれ、
前記処理実行手段は、
前記一連の処理のそれぞれの処理毎に、該一連の処理に関する情報と前記コンポーネントに関する情報と基づき、前記第1のコンポーネント又は前記第2のコンポーネントのいずれを生成するかを判別する判別手段を有し、
前記判別手段による判別結果に応じて生成された第1のコンポーネント又は第2のコンポーネントを組み合わせて、前記電子データを用いた前記一連の処理を実行する、情報処理装置。
An information processing apparatus,
For each application that executes a series of processes using electronic data by combining components that execute the series of processes, application identification information for identifying the application, information on the series of processes, and the series of processes A first storage unit that associates and stores screen information of a screen for specifying the electronic data used for
Second storage means for storing information regarding the component;
When a first request including the application identification information is received from one of the one or more devices connected to the information processing apparatus, the first request is associated with the application identification information included in the first request and the first request is received. Transmission means for transmitting the screen information stored in the one storage means to the one device of the request source;
When a second request including information related to electronic data designated by the user is received from the one device via the screen displayed on the one device based on the screen information transmitted by the transmission unit, the application A series of processes based on the information on the series of processes stored in the first storage means in association with identification information using electronic data specified by the information on the electronic data included in the second request Processing execution means for
The components include a first component registered by a user and a second component incorporated in advance in the information processing apparatus.
The process execution means is
It has determination means for determining whether to generate the first component or the second component based on the information on the series of processes and the information on the components for each process of the series of processes. ,
An information processing apparatus that executes the series of processes using the electronic data by combining a first component or a second component generated according to the determination result by the determination unit.
1以上の情報処理装置が含まれる情報処理システムであって、電子データを用いた一連の処理を、該一連の処理それぞれを実行するコンポーネントを組み合わせて実行するアプリケーション毎に、該アプリケーションを識別するアプリ識別情報と、前記一連の処理に関する情報と、前記一連の処理に用いる前記電子データを指定させる画面の画面情報と、を関連付けて記憶する第1の記憶手段と、前記コンポーネントに関する情報を記憶する第2の記憶手段とを有する情報処理システムに用いられる情報処理方法において、
前記情報処理システムに接続される1以上の機器のうちの一の機器から前記アプリ識別情報を含む第1の要求を受け付けると、該第1の要求に含まれる該アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記画面情報を、要求元の前記一の機器に送信する送信手順と、
前記送信手順により送信された前記画面情報に基づき前記一の機器に表示された画面を介してユーザにより指定された電子データに関する情報を含む第2の要求を前記一の機器から受け付けると、前記アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記一連の処理に関する情報に基づく一連の処理を、前記第2の要求に含まれる前記電子データに関する情報により指定される電子データを用いて実行する処理実行手順と
を有し、
前記コンポーネントには、ユーザにより登録された第1のコンポーネントと、前記情報処理システムに予め組み込まれている第2のコンポーネントとが含まれ、
前記処理実行手順は、
前記一連の処理のそれぞれの処理毎に、該一連の処理に関する情報と前記コンポーネントに関する情報と基づき、前記第1のコンポーネント又は前記第2のコンポーネントのいずれを生成するかを判別する判別手順を含み、
前記判別手順での判別結果に応じて生成された第1のコンポーネント又は第2のコンポーネントを組み合わせて、前記電子データを用いた前記一連の処理を実行する、情報処理方法。
An information processing system that includes one or more information processing apparatuses, and is an application that identifies the application for each application that executes a series of processes using electronic data by combining components that execute the series of processes. First storage means for associating and storing identification information, information on the series of processes, and screen information of a screen for specifying the electronic data used in the series of processes, and storing information on the components In an information processing method used in an information processing system having two storage means,
When a first request including the application identification information is received from one of the one or more devices connected to the information processing system, the first request is associated with the application identification information included in the first request. A transmission procedure for transmitting the screen information stored in the first storage unit to the one device of the request source;
When a second request including information related to electronic data specified by the user is received from the one device via the screen displayed on the one device based on the screen information transmitted by the transmission procedure, the application A series of processes based on the information on the series of processes stored in the first storage means in association with identification information using electronic data specified by the information on the electronic data included in the second request Process execution procedure to execute
The components include a first component registered by a user and a second component incorporated in advance in the information processing system.
The process execution procedure is
Each process of the series of processes includes a determination procedure of determining whether to generate the first component or the second component based on the information on the series of processes and the information on the components,
An information processing method , comprising combining the first component or the second component generated according to the determination result in the determination procedure, and executing the series of processes using the electronic data .
電子データを用いた一連の処理を、該一連の処理それぞれを実行するコンポーネントを組み合わせて実行するアプリケーション毎に、該アプリケーションを識別するアプリ識別情報と、前記一連の処理に関する情報と、前記一連の処理に用いる前記電子データを指定させる画面の画面情報と、を関連付けて記憶する第1の記憶手段と、前記コンポーネントに関する情報を記憶する第2の記憶手段とを有する情報処理装置に、
前記情報処理装置に接続される1以上の機器のうちの一の機器から前記アプリ識別情報を含む第1の要求を受け付けると、該第1の要求に含まれる該アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記画面情報を、要求元の前記一の機器に送信する送信手順、
前記送信手順により送信された前記画面情報に基づき前記一の機器に表示された画面を介してユーザにより指定された電子データに関する情報を含む第2の要求を前記一の機器から受け付けると、前記アプリ識別情報に関連付けて前記第1の記憶手段に記憶されている前記一連の処理に関する情報に基づく一連の処理を、前記第2の要求に含まれる前記電子データに関する情報により指定される電子データを用いて実行する処理実行手順
を実行させ、
前記コンポーネントには、ユーザにより登録された第1のコンポーネントと、前記情報処理装置に予め組み込まれている第2のコンポーネントとが含まれ、
前記処理実行手順は、
前記一連の処理のそれぞれの処理毎に、該一連の処理に関する情報と前記コンポーネントに関する情報と基づき、前記第1のコンポーネント又は前記第2のコンポーネントのいずれを生成するかを判別する判別手順を含み、
前記判別手順での判別結果に応じて生成された第1のコンポーネント又は第2のコンポーネントを組み合わせて、前記電子データを用いた前記一連の処理を実行する、プログラム。
For each application that executes a series of processes using electronic data by combining components that execute the series of processes, application identification information for identifying the application, information on the series of processes, and the series of processes An information processing apparatus comprising: first storage means for storing screen information of a screen for specifying the electronic data to be used in association with each other; and second storage means for storing information on the component.
When a first request including the application identification information is received from one of the one or more devices connected to the information processing apparatus, the first request is associated with the application identification information included in the first request and the first request is received. A transmission procedure for transmitting the screen information stored in the first storage unit to the one device of the request source;
When a second request including information related to electronic data specified by the user is received from the one device via the screen displayed on the one device based on the screen information transmitted by the transmission procedure, the application A series of processes based on the information on the series of processes stored in the first storage means in association with identification information using electronic data specified by the information on the electronic data included in the second request Process execution procedure to be executed
The components include a first component registered by a user and a second component incorporated in advance in the information processing apparatus.
The process execution procedure is
Each process of the series of processes includes a determination procedure of determining whether to generate the first component or the second component based on the information on the series of processes and the information on the components,
A program for executing the series of processes using the electronic data by combining a first component or a second component generated according to the determination result in the determination procedure .
JP2015181193A 2015-09-14 2015-09-14 INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM Active JP6536308B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2015181193A JP6536308B2 (en) 2015-09-14 2015-09-14 INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2015181193A JP6536308B2 (en) 2015-09-14 2015-09-14 INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2019106077A Division JP6753489B2 (en) 2019-06-06 2019-06-06 Information processing system, information processing device, information processing method, and program

Publications (2)

Publication Number Publication Date
JP2017058791A JP2017058791A (en) 2017-03-23
JP6536308B2 true JP6536308B2 (en) 2019-07-03

Family

ID=58390327

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2015181193A Active JP6536308B2 (en) 2015-09-14 2015-09-14 INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM

Country Status (1)

Country Link
JP (1) JP6536308B2 (en)

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH1124904A (en) * 1997-07-01 1999-01-29 Mitsubishi Electric Corp Program generation device and storage medium storing program generation program
JPH11161483A (en) * 1997-11-27 1999-06-18 Fujitsu Ltd System and method for constructing software provided with dynamic expandability
JP3732816B2 (en) * 2002-09-18 2006-01-11 エヌ・ティ・ティ・コムウェア株式会社 Application development support system, application development support method, and computer program
JP4419629B2 (en) * 2004-03-22 2010-02-24 富士ゼロックス株式会社 Image processing apparatus, processing system, and image processing method
JP2007072546A (en) * 2005-09-05 2007-03-22 Nomura Research Institute Ltd Flow editing device and flow editing method
JP5814526B2 (en) * 2010-08-26 2015-11-17 キヤノン株式会社 Image forming apparatus, image forming apparatus control method, and program
JP2014127066A (en) * 2012-12-27 2014-07-07 Ricoh Co Ltd Information processor, information processing system, and program
JP2014186473A (en) * 2013-03-22 2014-10-02 Fuji Xerox Co Ltd Program and device
JP2014186508A (en) * 2013-03-22 2014-10-02 Canon Inc Programming apparatus, programming support method and program

Also Published As

Publication number Publication date
JP2017058791A (en) 2017-03-23

Similar Documents

Publication Publication Date Title
US10122870B2 (en) Information processing system, information processing apparatus, and information processing method
US11150941B2 (en) Information processing system, information processing apparatus, method for processing information, and recording medium for handling process flow information
US10372485B2 (en) Information processing system, information processing apparatus, method for processing information, and recording medium
US10114940B2 (en) Information processing system, information processing apparatus, and information processing method
US9794447B2 (en) Service providing system, cooperation processing method, and information processing system
US10768975B2 (en) Information processing system, information processing apparatus, and information processing method
US10992831B2 (en) Information processing system for setting dependency relationships for input items on a screen related to a process flow
US20200097162A1 (en) Information processing system, service providing system, and flow setting method
CN107710176B (en) Information processing apparatus, method, program, system, and recording medium
US10516791B2 (en) Information processing system, information processing apparatus, and information processing method for executing an iteration of one or more processes
US10778862B2 (en) Information processing system, information processing method, and computer-readable recording medium
US20180060131A1 (en) Information processing system, information processing apparatus, and information processing method
US9904499B2 (en) Information processing system for dynamically adding a process to a sequence of processes and information processing method using same
JP6756270B2 (en) Information processing system, information processing device, information processing method, and program
US20200125903A1 (en) Document generation system, method of controlling the same, and non-transitory computer readable medium
US10348926B2 (en) Information processing system, information processing apparatus, and information processing method
US10425549B2 (en) Information processing apparatus, method of controlling information processing apparatus, and program
JP7444208B2 (en) Information processing system, information processing device, information processing method, and program
JP6753489B2 (en) Information processing system, information processing device, information processing method, and program
JP6536308B2 (en) INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, INFORMATION PROCESSING METHOD, AND PROGRAM
JP2017033218A (en) Information processing system, information processing device, and information processing method
JP2024056998A (en) Information processing system, information processing device, information processing method, and program
JP6544133B2 (en) INFORMATION PROCESSING SYSTEM, INFORMATION PROCESSING DEVICE, AND INFORMATION PROCESSING METHOD
JP2017130189A (en) Information processing system, information processing device, and information processing method
JP2017079030A (en) Information processing system, information processing unit and information processing method

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20180808

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20190131

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20190226

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190418

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20190507

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20190520

R151 Written notification of patent or utility model registration

Ref document number: 6536308

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151