JP6696326B2 - Information processing system, information processing apparatus, and information processing method - Google Patents
Information processing system, information processing apparatus, and information processing method Download PDFInfo
- Publication number
- JP6696326B2 JP6696326B2 JP2016128645A JP2016128645A JP6696326B2 JP 6696326 B2 JP6696326 B2 JP 6696326B2 JP 2016128645 A JP2016128645 A JP 2016128645A JP 2016128645 A JP2016128645 A JP 2016128645A JP 6696326 B2 JP6696326 B2 JP 6696326B2
- Authority
- JP
- Japan
- Prior art keywords
- information
- authentication
- job
- flow
- application
- 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
Links
Images
Landscapes
- Control Or Security For Electrophotography (AREA)
- Facsimiles In General (AREA)
Description
本発明は、情報処理システム、情報処理装置、及び情報処理方法に関する。 The present invention relates to an information processing system, an information processing device, and an information processing method.
近年、複数の機能(例えば、スキャンやプリント、メール配信等)を組み合わせた機能を提供するサービスが知られるようになった。例えば、スキャンにより生成された電子データをメール配信するサービス等が知られている。このようなサービスは、各機能を実現する1以上の処理が一連の処理としてジョブ実行されることにより実現される。 In recent years, services that provide functions that combine a plurality of functions (for example, scanning, printing, mail delivery, etc.) have become known. For example, a service and the like that delivers electronic data generated by scanning by mail is known. Such a service is realized by executing a job as a series of one or more processes for realizing each function.
また、1以上の処理を一連の処理として表した処理情報等が含まれる指示書に基づいて、当該一連の処理を実行する画像形成装置が知られている(例えば特許文献1参照)。 There is also known an image forming apparatus that executes a series of processes based on an instruction sheet including process information that represents one or more processes as a series of processes (see, for example, Patent Document 1).
上記のようなサービスは、例えば、機器に搭載されたアプリケーションを用いて、一連の処理を実行させることで利用することができる。ここで、機器に搭載されたアプリケーションが一連の処理を実行する場合には、不正利用の防止等の観点から当該アプリケーションの認証を行うことが好ましい。 The service as described above can be used by executing a series of processes using an application installed in the device, for example. Here, when the application installed in the device executes a series of processes, it is preferable to authenticate the application from the viewpoint of prevention of illegal use.
本発明の実施の形態は、上記の点に鑑みてなされたもので、一連の処理の実行前に機器を認証することを目的とする。 The embodiment of the present invention has been made in view of the above points, and an object thereof is to authenticate a device before executing a series of processes.
上記目的を達成するため、本発明の実施の形態は、1以上の情報処理装置を含み、所定の処理をそれぞれ実行する複数のプログラムを有する情報処理システムであって、電子データを用いた一連の処理毎に、該一連の処理のそれぞれの処理を実行する1以上の前記プログラムを識別するプログラム識別情報と、1以上の前記プログラムの実行順とが定義されたフロー情報を、該フロー情報を識別するフロー識別情報と関連付けて記憶する記憶手段と、前記情報処理システムに接続される1以上の機器のうちの一の機器から、電子データに関する情報と、前記フロー識別情報と、前記一の機器の認証を行うための認証情報とを含む第1の要求を受信する第1の受信手段と、前記第1の受信手段により受信された前記第1の要求に含まれる前記認証情報に基づいて、前記一の機器の認証を行う認証手段と、前記認証手段による前記認証が成功した場合、前記記憶手段に記憶されているフロー情報のうち、前記第1の受信手段により受信された前記第1の要求に含まれる前記フロー識別情報と関連付けて前記記憶手段に記憶されている前記フロー情報を取得する取得手段と、前記取得手段により取得された前記フロー情報に定義されている前記プログラム識別情報に識別されるプログラムそれぞれを、前記フロー情報に定義されている前記実行順に従って実行させることで、前記第1の受信手段により受信された前記第1の要求に含まれる前記電子データに関する情報に基づく電子データを用いた前記一連の処理を実行する実行手段と、を有する。 In order to achieve the above object, an embodiment of the present invention is an information processing system including one or more information processing devices and having a plurality of programs that respectively execute predetermined processes, and a series of electronic data is used. For each process, the flow information defining the program identification information that identifies one or more programs that execute each of the series of processes and the execution order of the one or more programs is identified. Information relating to electronic data from one of the one or more devices connected to the information processing system, the flow identification information, and the storage device that stores the flow identification information. Based on the first receiving means for receiving a first request including authentication information for performing authentication, and the authentication information included in the first request received by the first receiving means, An authentication unit that authenticates one device, and if the authentication by the authentication unit is successful, the first request received by the first receiving unit out of the flow information stored in the storage unit. Identified by the acquisition means for acquiring the flow information stored in the storage means in association with the flow identification information included in the flow identification information, and the program identification information defined in the flow information acquired by the acquisition means. By executing each of the programs according to the execution order defined in the flow information, the electronic data based on the information about the electronic data included in the first request received by the first receiving unit is stored. And an execution unit that executes the series of processes used.
本発明の実施の形態によれば、一連の処理の実行前に機器を認証することができる。 According to the embodiment of the present invention, it is possible to authenticate a device before executing a series of processes.
以下、本発明の実施形態について、図面を参照しながら詳細に説明する。 Hereinafter, embodiments of the present invention will be described in detail with reference to the drawings.
<システム構成>
まず、本実施形態に係る情報処理システム1のシステム構成について、図1を参照しながら説明する。図1は、本実施形態に係る情報処理システム1の一例のシステム構成を示す図である。
<System configuration>
First, the system configuration of the
図1に示す情報処理システム1は、サービス提供システム10と、機器20とを含み、インターネット等の広域的なネットワークN1を介して通信可能に接続されている。
The
サービス提供システム10は、一台以上の情報処理装置で実現され、ネットワークN1を介して、種々の機能をそれぞれ実現する複数の処理のうちの1以上の処理を組み合わせた一連の処理により実現される各種のサービスを提供する。
The
ここで、機能とは、文書ファイルや画像ファイル等の電子ファイルに関する機能である。機能には、例えば、プリント、スキャン、ファクシミリ送信、データ形式の変換、メール配信、OCR(Optical character recognition)処理、加工や圧縮・解凍、リポジトリへの格納等が挙げられる。 Here, the function is a function related to an electronic file such as a document file or an image file. The functions include, for example, printing, scanning, facsimile transmission, data format conversion, mail delivery, OCR (Optical character recognition) processing, processing, compression / decompression, and storage in a repository.
本実施形態に係るサービス提供システム10が提供するサービスの具体例については後述する。なお、以降では、一連の処理を「処理フロー」とも表す。
Specific examples of services provided by the
機器20は、ユーザが使用する各種の電子機器である。すなわち、機器20は、例えば、MFP(Multifunction Peripheral)等の画像形成装置、PC(パーソナルコンピュータ)、プロジェクタ、電子黒板、デジタルカメラ等である。ユーザは、機器20を用いて、サービス提供システム10が提供する各種のサービスを利用することができる。
The
なお、以降では、複数の機器20について、各々を区別するときは、「機器201」、「機器202」等と添え字を用いて記載する。
In addition, hereinafter, when distinguishing each of the plurality of
また、図1に示す情報処理システム1の構成は一例であって、他の構成であっても良い。例えば、本実施形態に係る情報処理システム1には、電子データの入力及び出力の少なくとも一方を行う各種機器が含まれ、これらの機器がサービス提供システム10により提供されるサービスを利用しても良い。
The configuration of the
<ハードウェア構成>
次に、本実施形態に係る情報処理システム1に含まれるサービス提供システム10のハードウェア構成について、図2を参照しながら説明する。図2は、本実施形態に係るサービス提供システム10の一例のハードウェア構成を示す図である。
<Hardware configuration>
Next, the hardware configuration of the
図2に示すサービス提供システム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
入力装置11は、キーボードやマウス、タッチパネル等を含み、ユーザが各操作信号を入力するのに用いられる。表示装置12は、ディスプレイ等を含み、サービス提供システム10による処理結果を表示する。なお、入力装置11及び表示装置12の少なくとも一方は、必要なときにサービス提供システム10に接続して利用する形態であっても良い。
The
通信I/F17は、サービス提供システム10をネットワークN1に接続するインタフェースである。これにより、サービス提供システム10は、通信I/F17を介して通信を行うことができる。
The communication I /
HDD18は、プログラムやデータを格納している不揮発性の記憶装置である。HDD18に格納されるプログラムやデータには、サービス提供システム10全体を制御する基本ソフトウェアであるOS(Operating System)、OS上において各種機能を提供するアプリケーションソフトウェア等がある。
The HDD 18 is a non-volatile storage device that stores programs and data. The programs and data stored in the HDD 18 include an OS (Operating System) that is basic software that controls the entire
なお、サービス提供システム10は、HDD18に代え、記憶媒体としてフラッシュメモリを用いるドライブ装置(例えばソリッドステートドライブ:SSD)を利用するものであっても良い。また、HDD18は、格納しているプログラムやデータを所定のファイルシステム及び/又はDBにより管理している。
The
外部I/F13は、外部装置とのインタフェースである。外部装置には、記録媒体13a等がある。これにより、サービス提供システム10は、外部I/F13を介して記録媒体13aの読み取りや書き込みを行うことができる。記録媒体13aには、フレキシブルディスク、CD、DVD、SDメモリカード、USBメモリ等がある。
The external I /
ROM15は、電源を切ってもプログラムやデータを保持することができる不揮発性の半導体メモリである。ROM15には、サービス提供システム10の起動時に実行されるBIOS(Basic Input/Output System)、OS設定、及びネットワーク設定等のプログラムやデータが格納されている。RAM14は、プログラムやデータを一時保持する揮発性の半導体メモリである。
The
CPU16は、ROM15やHDD18等の記憶装置からプログラムやデータをRAM14上に読み出し、処理を実行することで、サービス提供システム10全体の制御や機能を実現する演算装置である。
The
本実施形態に係るサービス提供システム10は、図2に示すハードウェア構成を有することにより、後述するような各種処理を実現できる。
The
次に、本実施形態に係る情報処理システム1に含まれる機器20が画像形成装置である場合のハードウェア構成について、図3を参照しながら説明する。図3は、本実施形態に係る機器20の一例のハードウェア構成を示す図である。
Next, a hardware configuration when the
図3に示す機器20は、コントローラ21と、操作パネル22と、外部I/F23と、通信I/F24と、プリンタ25と、スキャナ26とを有する。また、コントローラ21は、CPU31と、RAM32と、ROM33と、NVRAM34と、HDD35とを有する。
The
ROM33は、各種プログラムやデータを格納している不揮発性の半導体メモリである。RAM32は、プログラムやデータを一時保持する揮発性の半導体メモリである。NVRAM34は、例えば設定情報等を格納している。また、HDD35は、各種プログラムやデータを格納している不揮発性の記憶装置である。
The
CPU31は、ROM33やNVRAM34、HDD35等からプログラムやデータ、設定情報等をRAM32上に読み出し、処理を実行することで、機器20全体の制御や機能を実現する演算装置である。
The
操作パネル22は、ユーザからの入力を受け付ける入力部と、表示を行う表示部とを備えている。外部I/F23は、外部装置とのインタフェースである。外部装置には、記録媒体23a等がある。これにより、機器20は、外部I/F23を介して記録媒体23aの読み取り及び/又は書き込みを行うことができる。なお、記録媒体23aには、例えば、ICカード、フレキシブルディスク、CD、DVD、SDメモリカード、USBメモリ等がある。
The
通信I/F24は、機器20をネットワークに接続するインタフェースである。これにより、機器20は、通信I/F24を介して通信を行うことができる。プリンタ25は、印刷データを印刷する印刷装置である。スキャナ26は、原稿を読み取って電子ファイル(画像ファイル)を生成する読取装置である。
The communication I /
本実施形態に係る機器20は、図3に示すハードウェア構成を有することにより、後述するような各種処理を実現できる。
By having the hardware configuration shown in FIG. 3, the
<サービス提供システムが提供するサービス>
ここで、本実施形態に係るサービス提供システム10が提供するサービスについて説明する。なお、以降では、機器20が画像形成装置であるものとして説明する。
<Services provided by the service providing system>
Here, the services provided by the
本実施形態に係るサービス提供システム10は、機器20において原稿をスキャンして生成された電子ファイル(画像ファイル)をOCR処理して、ユーザにより指定されたメールアドレス宛にメール配信するサービスを提供する。
The
以降では、本実施形態に係るサービス提供システム10は、上述したサービス(「スキャン To メール配信」サービス)を提供するものとして説明する。
Hereinafter, the
ただし、サービス提供システム10が提供するサービスは、これに限られない。サービス提供システム10は、例えば、機器20において原稿をスキャンして生成された電子ファイルを圧縮して、リポジトリへ格納するサービスを提供しても良い。また、サービス提供システム10は、例えば、機器20において原稿をスキャンして生成された電子ファイルを加工(例えば、当該電子ファイルに所定の文言を付加)して、ファクシミリ送信するサービスを提供しても良い。
However, the service provided by the
また、例えば、機器20が電子黒板等である場合には、本実施形態に係るサービス提供システム10は、電子黒板である機器20により生成された電子ファイルを加工して、メール配信するサービス等を提供しても良い。
Further, for example, when the
<機能構成>
次に、本実施形態に係る情報処理システム1の機能構成について、図4を参照しながら説明する。図4は、本実施形態に係る情報処理システム1の一例の機能構成を示す図である。
<Functional configuration>
Next, the functional configuration of the
図4に示す機器20は、例えばCPU31等により実行されるクライアントアプリケーション210を有する。クライアントアプリケーション210は、サービス提供システム10が提供するサービスを利用するためのアプリケーションプログラムである。ユーザは、機器20にインストールされたクライアントアプリケーション210を用いて、サービス提供システム10が提供する「スキャン To メール配信」サービスを利用することができる。なお、クライアントアプリケーション210には、当該クライアントアプリケーション210を識別するアプリIDが付与されている。
The
図4に示すサービス提供システム10は、入出力サービス処理部110と、認証サービス部120と、ドキュメントサービス部130とを有する。これら各機能部は、サービス提供システム10にインストールされた1以上のプログラムが、CPU16に実行させる処理により実現される。
The
また、図5に示すサービス提供システム10は、アプリ情報記憶部140と、ジョブ情報記憶部150と、参照情報記憶部160とを有する。これら各記憶部は、HDD18を用いて実現可能である。なお、これら各記憶部のうちの少なくとも一の記憶部が、サービス提供システム10とネットワークN1を介して接続される記憶装置等を用いて実現されていても良い。
Further, the
入出力サービス処理部110は、サービス提供システム10が提供するサービスに関する処理を行う。ここで、入出力サービス処理部110は、アプリ管理部111と、ロジック処理部112と、ジョブ管理部113とを有する。
The input / output
アプリ管理部111は、アプリ情報記憶部140に記憶されているアプリ情報1000と、参照情報記憶部160に記憶されている参照情報を管理する。
The
なお、アプリ情報1000とは、一連の処理により実現されるサービスを提供するためのアプリケーションである。すなわち、サービス提供システム10が提供する各種のサービス(例えば、「スキャン To メール配信」サービス)は、アプリ情報1000により提供される。また、参照情報とは、クライアントアプリケーション210やアプリ情報1000等が、他のクライアントアプリケーション210やアプリ情報1000等により実行されたジョブの情報(ジョブ情報)を参照可能であるか否かを判定するための情報である。
The
また、アプリ管理部111は、ロジック処理部112からの要求に応じて、アプリ情報1000に含まれる処理フロー情報1100を返信する。なお、処理フロー情報1100とは、アプリ情報1000により提供されるサービスを実現する一連の処理が定義された情報である。
The
ロジック処理部112は、クライアントアプリケーション210からの要求に応じて、アプリ情報1000に含まれる処理フロー情報1100をアプリ管理部111から取得する。そして、ロジック処理部112は、アプリ管理部111から取得した処理フロー情報1100に基づいて、当該アプリ情報1000が提供するサービスを実現する一連の処理(処理フロー)を実行する。これにより、本実施形態に係るサービス提供システム10は、各種のサービス(例えば、「スキャン To メール配信」サービス)を提供することができる。
The
ジョブ管理部113は、ジョブ情報記憶部150に記憶されているジョブ情報を管理する。なお、ジョブ情報とは、ジョブに関する各種情報(例えば、ジョブの作成日や状態等)が含まれる情報である。また、ジョブとは、各種のサービスを実現する一連の処理(処理フロー)を1つの実行単位とした概念である。
The
認証サービス部120は、クライアントアプリケーション210が入出力サービス処理部110に各種要求を行う際に、様々な認証方式により認証を行う。
The
ドキュメントサービス部130は、処理フロー情報1100に基づく一連の処理(処理フロー)に含まれる所定の処理を実行する。ここで、ドキュメントサービス部130は、OCR処理部131と、メール配信部132とを有する。
The
OCR処理部131は、電子ファイル(画像ファイル)に対してOCR処理を行う。メール配信部132は、電子ファイルを添付したメールを作成して、当該メールを指定されたメールアドレス宛に配信する。
The OCR processing unit 131 performs OCR processing on an electronic file (image file). The
なお、ドキュメントサービス部130は、例えば、電子ファイルのデータ形式を所定のデータに変換するデータ変換部、電子ファイルを圧縮又は解凍する圧縮・解凍部等を有していても良い。
The
このように、ドキュメントサービス部130には、一連の処理(処理フロー)に含まれる所定の処理を実行する種々の機能部が含まれる。したがって、ドキュメントサービス部130は、これら種々の機能を提供するプログラム(モジュール)群により実現される。
As described above, the
アプリ情報記憶部140は、アプリ情報1000を記憶する。アプリ情報1000は、当該アプリ情報1000を識別するアプリIDと関連付けてアプリ情報記憶部140に記憶されている。したがって、アプリIDは、クライアントアプリケーション210及びアプリ情報1000を識別する識別情報である。
The application
ここで、アプリ情報1000には、処理フロー情報1100が含まれる。例えば、「スキャン To メール配信」サービスを提供するアプリ情報1000には、当該サービスを実現する一連の処理が定義された処理フロー情報1100が含まれる。すなわち、「スキャン To メール配信」サービスを提供するアプリ情報1000には、スキャンにより生成された電子ファイルをOCR処理した後、指定されたメールアドレス宛にメール配信する処理が定義された処理フロー情報1100が含まれる。
Here, the
なお、アプリ情報1000には、2以上の処理フロー情報1100が含まれていても良い。例えば、「スキャン To メール配信」を提供するアプリ情報1000には、英語でOCR処理した後、メール配信する処理が定義された処理フロー情報1100Aと、日本語でOCR処理した後、メール配信する処理が定義された処理フロー情報1100Bとが含まれていても良い。
The
処理フロー情報1100は、上述したように、アプリ情報1000により提供されるサービスを実現する一連の処理(処理フロー)が定義された情報である。処理フロー情報1100には、当該処理フロー情報1100を識別するフローIDが付与されている。なお、処理フロー情報1100の詳細については後述する。
As described above, the
ジョブ情報記憶部150は、ジョブ情報を記憶する。参照情報記憶部160は、参照情報を記憶する。ジョブ情報及び参照情報の詳細については後述する。
The job
なお、入出力サービス処理部110、認証サービス部120、及びドキュメントサービス部130は、それぞれが異なる情報処理装置により実現されていても良い。
The input / output
ここで、ロジック処理部112の詳細な機能構成について、図5を参照しながら説明する。図5は、本実施形態に係るロジック処理部112の一例の機能構成図である。
Here, a detailed functional configuration of the
図5に示すロジック処理部112は、フロー実行部301と、コンポーネント管理部302と、コンポーネント群303と、型変換管理部304と、型変換群305とを有する。また、ロジック処理部112は、型変換情報テーブル3000を有する。
The
フロー実行部301は、認証サービス部120を介して、クライアントアプリケーション210からアプリケーションの実行要求を受信すると、当該実行要求に対応するアプリ情報1000に含まれる処理フロー情報1100をアプリ管理部111から取得する。そして、フロー実行部301は、アプリ管理部111から取得した処理フロー情報1100に基づく一連の処理(処理フロー)を実行する。
When receiving the application execution request from the
ここで、処理フロー情報1100に基づく一連の処理は、当該一連の処理に含まれる各処理を実行するためのコンポーネントを組み合わせることにより実行される。なお、コンポーネントは、所定の機能を実現する処理を実行するためのプログラムやモジュール等により実現され、例えばクラスや関数等で定義される。
Here, a series of processes based on the
コンポーネント管理部302は、コンポーネントを管理する。コンポーネント管理部302は、フロー実行部301からの要求に応じて、コンポーネントを生成すると共に、生成したコンポーネントをフロー実行部301に返信する。なお、コンポーネントの生成とは、例えばクラスや関数等で定義されたコンポーネントを、メモリ(例えばRAM14)上に展開することである。
The
コンポーネント群303は、コンポーネントの集合である。コンポーネント群303には、OCRコンポーネント1310と、メール配信コンポーネント1320とが含まれる。
The
OCRコンポーネント1310は、電子ファイルをOCR処理するためのコンポーネントである。OCRコンポーネント1310は、ドキュメントサービス部130のOCR処理部131にOCR処理を要求することにより、電子ファイルのOCR処理を行う。
The
メール配信コンポーネント1320は、指定されたメールアドレス宛にメール配信するためのコンポーネントである。メール配信コンポーネント1320は、ドキュメントサービス部130のメール配信部132にメール配信処理を要求することにより、指定されたメールアドレス宛にメールを配信する。
The
このように、各コンポーネントは、ドキュメントサービス部130を利用して、所定の機能を実現する処理を実行する。なお、コンポーネント群303には、上記のコンポーネント以外にも、例えば、電子ファイルのデータ形式を所定のデータ形式に変換するための変換コンポーネント、電子ファイルを圧縮するための圧縮コンポーネント等の各種のコンポーネントが含まれる。
In this way, each component uses the
また、コンポーネント群303に含まれる各コンポーネントは、コンポーネント共通I/F1300を有する。コンポーネント共通I/F1300は、各コンポーネントに対して共通に定義されたAPI(Application Programming Interface)であり、コンポーネントを生成するためのAPIと、コンポーネントの処理を実行するためのAPIとが含まれる。
Further, each component included in the
このように、各コンポーネントがコンポーネント共通I/F1300を有することで、コンポーネントの追加等に伴う影響を局所化することができる。すなわち、例えば、フロー実行部301やコンポーネント管理部302等に影響を与えることなく、コンポーネントの追加等を行うことができる。これにより、本実施形態に係るサービス提供システム10では、所定の機能の追加等(すなわち、当該機能を実現する処理を実行するためのコンポーネントの追加等)に伴う開発工数を削減することができる。
As described above, since each component has the component common I /
型変換管理部304は、データ型の型変換を管理する。ここで、各コンポーネントは、自身が扱えるデータ型が予め決まっている。したがって、型変換管理部304は、コンポーネントからの要求に応じて、例えば図6に示す型変換情報テーブル3000を参照して、型変換群305に含まれる型変換を生成する。
The type
そして、型変換管理部304は、生成された型変換に型変換処理の実行を要求する。なお、型変換は、データ型の型変換処理を実行するプログラムやモジュール等により実現され、例えばクラスや関数等で定義される。また、型変換の生成とは、例えばクラスや関数等で定義された型変換を、メモリ(例えばRAM14上)に展開することである。
Then, the type
なお、データ型には、例えば、ストリームデータを示すデータ型「InputStream」、記憶装置等に格納されている電子ファイルのパス(アドレス)を示す「LocalFilePath」、及び電子ファイルの実体を示す「File」等が挙げられる。 The data type is, for example, a data type “InputStream” indicating stream data, “LocalFilePath” indicating a path (address) of an electronic file stored in a storage device, and “File” indicating the substance of the electronic file. Etc.
ここで、型変換情報テーブル3000について、図6を参照しながら説明する。図6は、型変換情報テーブルの一例を示す図である。 Here, the type conversion information table 3000 will be described with reference to FIG. FIG. 6 is a diagram showing an example of the type conversion information table.
図6に示す型変換情報テーブル3000は、データ項目として、変換前のデータ型と、変換後のデータ型と、生成する型変換とを有する。すなわち、型変換情報テーブル3000に格納されている型変換情報は、変換前のデータ型及び変換後のデータ型毎に、当該変換前のデータ型を、当該変換後のデータ型に変換するための型変換が関連付けられた情報である。 The type conversion information table 3000 illustrated in FIG. 6 has, as data items, a data type before conversion, a data type after conversion, and a type conversion to be generated. That is, the type conversion information stored in the type conversion information table 3000 is for converting the data type before conversion into the data type after conversion for each of the data type before conversion and the data type after conversion. This is the information associated with the type conversion.
型変換群305は、型変換の集合である。型変換群305には、データ型「InputStream」を「LocalFilePath」に変換するための第1の型変換1410が含まれる。なお、型変換群305には、これ以外にも、例えば、データ型「LocalFilePath」を「File」に変換するための第2の型変換等が含まれる。
The
また、型変換群305に含まれる各型変換は、型変換共通I/F1400を有する。型変換共通I/F1400は、各型変換に対して共通に定義されたAPIであり、型変換を生成するためのAPIと、型変換の型変換処理を実行するためのAPIとが含まれる。
Further, each type conversion included in the
このように、各型変換が型変換共通I/F1400を有することで、型変換の追加等に伴う影響を局所化することができる。すなわち、例えば、型変換管理部304等に影響を与えることなく、型変換の追加等を行うことができる。これにより、本実施形態に係るサービス提供システム10では、型変換の追加等に伴う開発工数を削減することができる。
As described above, since each type conversion has the type conversion common I /
ここで、ジョブ管理部113の詳細な機能構成について、図7を参照しながら説明する。図7は、本実施形態に係るジョブ管理部113の一例の機能構成を示す図である。
Here, a detailed functional configuration of the
図7に示すジョブ管理部113は、ジョブ情報管理部401と、アクセス制御部402とを有する。
The
ジョブ情報管理部401は、ロジック処理部112からジョブ情報の登録要求を受信すると、ジョブ情報を作成して、ジョブ情報記憶部150に記憶する。これにより、ジョブ情報がサービス提供システム10に登録される。
Upon receiving the job information registration request from the
また、ジョブ情報管理部401は、アクセス制御部402からジョブ情報の取得要求を受信すると、ジョブ情報をジョブ情報記憶部150から取得する。そして、ジョブ情報管理部401は、取得したジョブ情報をアクセス制御部402に返信する。
Further, when the job
アクセス制御部402は、認証サービス部120を介して、クライアントアプリケーション210からジョブ情報の参照要求を受信すると、ジョブの情報取得要求をジョブ情報管理部401に送信する。
Upon receiving the job information reference request from the
また、アクセス制御部402は、ジョブ情報管理部401からジョブ情報が返信されると、アプリ管理部111を介して、参照情報に含まれるアプリID(後述する参照可能アプリID)を取得する。そして、アクセス制御部402は、ジョブ情報管理部401から返信されたジョブ情報をクライアントアプリケーション210が参照可能か否かを判定するためのアクセス権チェックを行う。
Further, when the job information is returned from the job
なお、参照情報には、クライアントアプリケーション210又はアプリ情報1000のアプリIDと、当該クライアントアプリケーション210又はアプリ情報1000が参照可能な他のアプリケーションのアプリID(参照可能アプリID)が関連付けられている。
The reference information is associated with the application ID of the
これにより、クライアントアプリケーション210等が、他のアプリケーション(他のクライアントアプリケーション210や他のアプリ情報1000)のジョブ情報を参照する場合のアクセス制御が行われる。
As a result, access control is performed when the
ここで、「スキャン To メール配信」サービスを提供するアプリ情報1000に含まれる処理フロー情報1100について、図8を参照しながら説明する。図8は、処理フロー情報1100の一例を示す図である。
Here, the
図8に示す処理フロー情報1100は、「スキャン To メール配信」サービスを実現する一連の処理(処理フロー)が定義された情報である。すなわち、図8に示す処理フロー情報1100には、フローID1101と、「スキャン To メール配信」サービスを実現する一連の処理を構成する各処理をそれぞれ示す処理定義1102及び処理定義1103とが定義されている。
The process flow
フローID1101は、図8に示す処理フロー情報1100を識別するフローIDである。
The
処理定義1102及び処理定義1103は、「コンポーネント名:処理内容?オプションパラメータ」の形式で定義される。なお、オプションパラメータは、例えば、コンポーネント名及び処理内容で示されるコンポーネントが処理を行うのに必要である場合に限り、定義されていれば良い(すなわち、オプションパラメータの定義は任意である。)。また、複数のオプションパラメータを定義する場合には、オプションパラメータ同士を「&」で結合することにより定義する。
The process definition 1102 and the
処理定義1102には、「ocr:ocr_process」が定義されている。これは、OCRコンポーネント1310によりOCR処理を行うこと意味している。なお、処理定義1102には、オプションパラメータは定義されていない。
In the process definition 1102, “ocr: ocr_process” is defined. This means that OCR processing is performed by the
処理定義1103には、「mail:send」が定義されている。これは、メール配信コンポーネント1320によりメール配信処理を行うことを意味している。
In the
また、処理定義1103には、「?mail_address=null&filename=null」が定義されている。これは、「mail_address」に指定されたメールアドレス宛に、「filename」に指定されたファイル名の電子ファイルをメール配信することを意味している。なお、図8に示す例では、「mail_address」及び「filename」には値が指定されていない(すなわち、nullである。)。
Further, in the
このように、処理フロー情報1100には、一連の処理(処理フロー)を構成する各処理の処理定義が定義されている。これにより、本実施形態に係るサービス提供システム10は、処理フロー情報1100に含まれる各処理定義に従って、各コンポーネントによる処理を行うことで、アプリ情報1000により提供されるサービスを実現する一連の処理を実行することができる。
As described above, in the
なお、図8に示す処理フロー情報1100に含まれる各処理定義に定義された処理は、上から順に実行される。すなわち、図8に示す処理フロー情報1100に基づく一連の処理では、処理定義1102に定義された処理、処理定義1103に定義された処理の順で実行される。ただし、これに限られず、処理フロー情報1100には、例えば、各処理定義に定義された処理の実行順を示す情報が定義されていても良い。
The processes defined in each process definition included in the
<処理の詳細>
次に、本実施形態に係る情報処理システム1の処理の詳細について説明する。まず、機器20のユーザが、「スキャン To メール配信」サービスを利用する場合の全体的な処理について、図9を参照しながら説明する。図9は、サービス利用の全体処理の一例を示すシーケンス図である。
<Details of processing>
Next, details of the processing of the
まず、クライアントアプリケーション210は、例えば図10に示すサービス利用画面2100を表示する(ステップS901)。このようなサービス利用画面2100は、例えば、ユーザがサービス利用画面2100の表示操作を行うことにより表示される。
First, the
図10に示すサービス利用画面2100には、ファイル名入力欄2101と、メールアドレス入力欄2102と、スキャン実行ボタン2103とが含まれる。
The
ファイル名入力欄2101は、メールに添付する電子ファイル(すなわち、スキャンにより生成された電子ファイルをOCR処理した電子ファイル)のファイル名をユーザが指定する入力エリアである。メールアドレス入力欄2102は、メールの配信先となるメールアドレスをユーザが指定する入力エリアである。スキャン実行ボタン2103は、原稿のスキャンを実行して、サービスの利用を開始するためのボタンである。
The file
ここで、図10に示すサービス利用画面2100において、ユーザにより、ファイル名入力欄2101及びメールアドレス入力欄2102にファイル名及びメールアドレスが指定された上で、スキャン実行ボタン2103を押下してスキャン実行操作がなされたものとする。
Here, on the
すると、クライアントアプリケーション210は、原稿をスキャナ26で読み取ることで画像ファイル(スキャン画像ファイル)を作成する(ステップS902)。
Then, the
ここで、クライアントアプリケーション210は、認証サービス部120との間の認証方式が「アプリ認証」である場合、クライアントIDとクライアントシークレットとを含む処理フローの実行要求を認証サービス部120に送信する(ステップS903)。
Here, when the authentication method between the
なお、クライアントIDは、例えば、クライアントアプリケーション210のアプリIDである。また、クライアントシークレットは、クライアントIDに対するパスワード等である。すなわち、処理フローの実行要求には、認証情報として、クライアントIDとクライアントシークレットとが含まれている。
The client ID is, for example, the application ID of the
また、処理フローの実行要求には、フローID、スキャン画像ファイル、及びユーザ指定情報も含まれる。なお、ユーザ指定情報とは、ファイル名入力欄2101及びメールアドレス入力欄2102にそれぞれ指定されたファイル名及びメールアドレスである。
The processing flow execution request also includes the flow ID, the scan image file, and the user designation information. The user-specified information is the file name and mail address specified in the file
例えば、ファイル名入力欄2101に「test.pdf」、メールアドレス入力欄2102に「hoge@hogehoge.co.jp」が指定されたとする。この場合、ユーザ指定情報は、「mail_address=hoge@hogehoge.co.jp」と、「filename=test.pdf」とを含む情報である。
For example, assume that “test.pdf” is specified in the file
次に、認証サービス部120は、処理フローの実行要求を受信すると、当該実行要求に含まれるクライアントID及びクライアントシークレットに基づいて、アプリ認証を行う(ステップS904)。すなわち、認証サービス部120は、当該実行要求に含まれるクライアントID及びクライアントシークレットの組が、予め決められたクライアントID及びクライアントシークレットの組と一致するか否かを判定することで、アプリ認証を行う。
Next, when the
そして、認証サービス部120は、アプリ認証に成功した場合、処理フローの実行要求をロジック処理部112に送信する(ステップS905)。なお、処理フローの実行要求には、フローIDと、スキャン画像ファイルと、ユーザ指定情報と、アプリIDとが含まれる。
Then, when the application authentication is successful, the
なお、認証サービス部120は、上記のステップS904でアプリ認証に失敗した場合、例えば、アプリ認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
When the application authentication fails in step S904 described above, the
クライアントアプリケーション210は、認証サービス部120との間の認証方式が「ユーザ認証」である場合、テナントIDと、ユーザIDと、パスワードとを含む処理フローの実行要求を認証サービス部120に送信する(ステップS906)。
When the authentication method between the
なお、テナントIDは、例えば、クライアントアプリケーション210が搭載された機器20のユーザが属するグループや会社等の組織を識別する識別情報である。また、ユーザIDは、例えば、クライアントアプリケーション210が搭載された機器20のユーザを識別する識別情報である。すなわち、処理フローの実行要求には、認証情報として、テナントIDと、ユーザIDと、パスワードとが含まれている。
The tenant ID is, for example, identification information that identifies an organization such as a group or a company to which the user of the
テナントID、ユーザID、及びパスワードは、例えば、図10に示すサービス利用画面2100において、ユーザにより入力されても良い。なお、処理フローの実行要求には、上記と同様に、フローID、スキャン画像ファイル、及びユーザ指定情報も含まれる。
The tenant ID, the user ID, and the password may be input by the user on the
次に、認証サービス部120は、処理フローの実行要求を受信すると、当該実行要求に含まれるテナントID、ユーザID、及びパスワードに基づいて、ユーザ認証を行う(ステップS907)。すなわち、認証サービス部120は、当該実行要求に含まれるテナントID、ユーザID、及びパスワードの組が、予め決められたテナントID、ユーザID、及びパスワードの組と一致するか否かを判定することで、ユーザ認証を行う。
Next, when the
そして、認証サービス部120は、ユーザ認証に成功した場合、処理フローの実行要求をロジック処理部112に送信する(ステップS908)。なお、処理フローの実行要求には、フローIDと、スキャン画像ファイルと、ユーザ指定情報と、ユーザIDとが含まれる。
Then, when the user authentication is successful, the
なお、認証サービス部120は、上記のステップS907でユーザ認証に失敗した場合、例えば、ユーザ認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
If the user authentication fails in step S907, the
クライアントアプリケーション210は、認証サービス部120との間の認証方式が「アクセストークン認証」である場合、アクセストークンを含む処理フローの実行要求を認証サービス部120に送信する(ステップS909)。
When the authentication method between the
なお、アクセストークンは、例えば、OAuthによる認証に用いられるトークンである。すなわち、処理フローの実行要求には、認証情報として、アクセストークンが含まれている。なお、処理フローの実行要求には、上記と同様に、フローID、スキャン画像ファイル、及びユーザ指定情報も含まれる。 The access token is, for example, a token used for authentication by OAuth. That is, the processing flow execution request includes the access token as the authentication information. The process flow execution request includes the flow ID, the scan image file, and the user designation information, as in the above.
次に、認証サービス部120は、処理フローの実行要求を受信すると、当該実行要求に含まれるアクセストークンに基づいて、アクセストークン認証を行う(ステップS910)。すなわち、認証サービス部120は、当該実行要求に含まれるアクセストークンが正当であるか否かを判定することで、アクセストークン認証を行う。
Next, when the
そして、認証サービス部120は、アクセストークン認証に成功した場合、処理フローの実行要求をロジック処理部112に送信する(ステップS911)。なお、処理フローの実行要求には、フローID、スキャン画像ファイル、ユーザ指定情報、及びアクセストークンに関連付けられたユーザIDが含まれる。
Then, when the access token authentication is successful, the
なお、認証サービス部120は、上記のステップS910でアクセストークン認証に失敗した場合、例えば、アクセストークン認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
In addition, when the access token authentication fails in step S910, the
最後に、ロジック処理部112は、処理フローの実行処理を行う(ステップS9126)。すなわち、ロジック処理部112は、当該実行要求に含まれるフローIDの処理フロー情報1100に基づく一連の処理を実行する。
Finally, the
そして、ロジック処理部112は、処理フローの実行処理の処理結果をクライアントアプリケーション210に返信する。これにより、本実施形態に係るサービス提供システム10は、機器20に対して、「スキャン To メール配信」サービスを提供することができる。
Then, the
ここで、クライアントアプリケーション210と認証サービス部120との間の認証方式が「アプリ認証」、「ユーザ認証」、又は「アクセストークン認証」のいずれであるかは、例えば、クライアントアプリケーション210毎に予め決められている。したがって、クライアントアプリケーション210は、例えば、認証方式の指定を含む処理フローの実行要求を認証サービス部120に送信する。ただし、例えば、図10に示すサービス利用画面2100において、いずれの認証方式を利用するかをユーザが選択することができても良い。
Here, whether the authentication method between the
以上のように、本実施形態に係る情報処理システム1では、サービス提供システム10が機器20に対してサービスを提供する前に、種々の認証方式により機器20との間で認証を行う。すなわち、本実施形態に係る情報処理システム1では、機器20に搭載されたクライアントアプリケーション210が一連の処理を実行させる前に、当該クライアントアプリケーション210の認証を行う。これにより、本実施形態に係るサービス提供システム10は、正当な利用者(機器20に搭載されたクライアントアプリケーション210又は機器20のユーザ)に限り、サービスを提供することができる。
As described above, in the
以降では、処理フローの実行処理(図9のステップS912の処理)の詳細について、図11を参照しながら説明する。図11は、本実施形態に係る処理フローの実行処理の一例を示すシーケンス図である。 Hereinafter, details of the process flow execution process (the process of step S912 in FIG. 9) will be described with reference to FIG. 11. FIG. 11 is a sequence diagram showing an example of execution processing of the processing flow according to the present embodiment.
フロー実行部301は、処理フローの実行要求を受信すると、ジョブ情報の登録要求をジョブ情報管理部401に送信する(ステップS1101)。ここで、クライアントアプリケーション210と認証サービス部120との間の認証方式が「アプリ認証」であった場合、ジョブ情報の登録要求には、アプリIDと、フローIDとが含まれる。一方、クライアントアプリケーション210と認証サービス部120との間の認証方式が「ユーザ認証」又は「アクセストークン認証」であった場合、ジョブ情報の登録要求には、ユーザIDと、フローIDとが含まれる。
Upon receiving the processing flow execution request, the
ジョブ情報管理部401は、ジョブ情報の登録要求を受信すると、ジョブ情報を作成して、ジョブ情報記憶部150に記憶する(ステップS1102)。そして、ジョブ情報管理部401は、登録結果をフロー実行部301に返信する。これにより、ジョブ情報がサービス提供システム10に登録される。なお、ジョブ情報管理部401から返信される登録結果には、ジョブIDが含まれる。
Upon receiving the job information registration request, the job
ここで、ジョブ情報記憶部150に記憶されたジョブ情報について、図12を参照しながら説明する。図12は、ジョブ情報の一例を示す図である。
Here, the job information stored in the job
図12に示すように、ジョブ情報は、ジョブIDと、アプリ名と、フローIDと、作成日と、状態と、アプリIDと、ユーザIDとを有する。 As shown in FIG. 12, the job information has a job ID, an application name, a flow ID, a creation date, a state, an application ID, and a user ID.
ジョブIDは、ジョブを識別する識別情報である。アプリ名は、アプリIDに対応するアプリケーション(クライアントアプリケーション210又はアプリ情報1000)の名称である。フローIDは、ジョブ情報の登録要求に含まれるフローIDである。作成日は、ジョブ情報が作成された年月日である。
The job ID is identification information that identifies a job. The application name is the name of the application (
状態は、ジョブの状態である。状態には、例えば、ジョブが実行される前であることを示す「accepted」、ジョブが実行中であることを示す「processing」がある。また、状態には、例えば、ジョブの実行中にエラーが発生したことを示す「error」、ジョブの実行が正常終了したことを示す「completed」等がある。なお、ジョブ情報管理部401は、状態を「accepted」としてジョブ情報を作成する。
The status is the status of the job. The state includes, for example, “accepted” indicating that the job is not yet executed and “processing” indicating that the job is being executed. Further, the status includes, for example, "error" indicating that an error has occurred during the execution of the job, "completed" indicating that the execution of the job has completed normally, and the like. The job
アプリIDは、ジョブ情報の登録要求に含まれていたアプリIDである。なお、ジョブ情報の登録要求にアプリIDが含まれない場合(すなわち、クライアントアプリケーション210と認証サービス部120との間の認証方式が「アプリ認証」であった場合)、アプリIDは、設定されない。
The application ID is the application ID included in the job information registration request. When the job information registration request does not include the application ID (that is, when the authentication method between the
ユーザIDは、ジョブ情報の登録要求に含まれていたユーザIDである。なお、ジョブ情報の登録要求にユーザIDが含まれない場合(すなわち、クライアントアプリケーション210と認証サービス部120との間の認証方式が「ユーザ認証」又は「アクセストークン認証」であった場合)、ユーザIDは、設定されない。
The user ID is the user ID included in the job information registration request. When the user information registration request does not include the user ID (that is, when the authentication method between the
このように、ジョブ情報管理部401は、ジョブID、アプリ名、フローID、作成日、状態、アプリID、及びユーザID等が含まれるジョブ情報を作成する。そして、ジョブ情報管理部401は、作成したジョブ情報をジョブ情報記憶部150に記憶させる。
In this way, the job
次に、フロー実行部301は、処理フロー情報の取得要求をアプリ管理部111に送信する(ステップS1103)。なお、処理フロー情報の取得要求には、フローIDが含まれる。
Next, the
アプリ管理部111は、処理フロー情報の取得要求を受信すると、当該取得要求に含まれるフローIDの処理フロー情報1100をアプリ情報記憶部140から取得する(ステップS1104)。そして、アプリ管理部111は、アプリ情報記憶部140から取得した処理フロー情報1100をフロー実行部301に返信する。ここで、以降では、アプリ管理部111は、図8に示す処理フロー情報1100をフロー実行部301に返信したものとして説明する。
Upon receiving the process flow information acquisition request, the
次に、フロー実行部301は、アプリ管理部111から返信された処理フロー情報1100に基づいて、コンポーネントの取得要求をコンポーネント管理部302に送信する(ステップS1105)。すなわち、フロー実行部301は、図8に示す処理フロー情報1100の処理定義1102に定義されている「ocr:ocr_process」を含むコンポーネントの取得要求をコンポーネント管理部302に送信する。
Next, the
コンポーネント管理部302は、コンポーネントの取得要求を受信すると、当該取得要求に含まれる「ocr:ocr_process」に対応するOCRコンポーネント1310を生成する(ステップS1106)。なお、OCRコンポーネント1310の生成は、コンポーネント共通I/F1300を用いて行うことができる。
Upon receiving the component acquisition request, the
そして、コンポーネント管理部302は、生成したOCRコンポーネント1310をフロー実行部301に返信する。すなわち、コンポーネント管理部302は、例えば、OCRコンポーネント1310が展開されたメモリ(例えばRAM14)上のアドレスをフロー実行部301に返信する。
Then, the
フロー実行部301は、OCRコンポーネント1310が返信されると、コンポーネントの処理実行要求を、当該OCRコンポーネント1310に送信する(ステップS1107)。なお、コンポーネントの処理実行要求には、データと、パラメータとが含まれる。
When the
ここで、ステップS1107において、データとは、データ型「InputStream」として、認証サービス部120から受信した電子ファイル(処理フローの実行要求に含まれるスキャン画像ファイル)である。すなわち、フロー実行部301は、処理フロー実行要求に含まれるスキャン画像ファイルを、単に「データ」として(データ型を意識することなく)、OCRコンポーネント1310に送信する。以降では、このようにデータ型を意識しない電子ファイル等を、単に「データ」と表す。
Here, in step S1107, the data is an electronic file (scan image file included in the execution request of the processing flow) received from the
また、処理定義1102にはオプションパラメータが定義されていないため、ステップS1107において、パラメータには、nullが指定される。 Since no optional parameter is defined in the process definition 1102, null is designated as the parameter in step S1107.
OCRコンポーネント1310は、コンポーネントの処理実行要求を受信すると、型変換要求を型変換管理部304に送信する(ステップS1108)。なお、当該型変換要求には、データと、OCRコンポーネント1310が扱うことができるデータ型を示す「LocalFilePath」の指定とが含まれる。
The
型変換管理部304は、型変換要求を受信すると、当該型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致するか否かをチェックする(ステップS1109)。
Upon receiving the type conversion request, the type
ここで、型変換要求に含まれるデータのデータ型は「InputStream」である一方、指定されたデータ型は「LocalFilePath」である。したがって、型変換管理部304は、型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致しないものと判断する。
Here, the data type of the data included in the type conversion request is “InputStream”, while the designated data type is “LocalFilePath”. Therefore, the type
すると、型変換管理部304は、型変換情報テーブル3000を参照して、データ型「InputStream」を「LocalFilePath」に変換するための型変換を特定する(ここでは、第1の型変換1410が特定される。)。そして、型変換管理部304は、特定した第1の型変換1410を生成する(ステップS1110)。なお、第1の型変換1410の生成は、型変換共通I/F1400を用いて行うことができる。
Then, the type
次に、型変換管理部304は、型変換処理の実行要求を第1の型変換1410に送信する(ステップS1111)。なお、当該実行要求には、データが含まれる。
Next, the type
第1の型変換1410は、型変換の実行要求を受信すると、当該実行要求に含まれるデータのデータ型を「InputStream」から「LocalFilePath」に変換する型変換処理を行う(ステップS1112)。そして、第1の型変換1410は、データ型が変換されたデータを型変換管理部304に返信する。
Upon receiving the type conversion execution request, the
型変換管理部304は、第1の型変換1410からデータを受信すると、当該データをOCRコンポーネント1310に送信する(ステップS1113)。
Upon receiving the data from the
OCRコンポーネント1310は、型変換管理部304からデータを受信すると、当該データに対して処理を実行する(ステップS1114)。すなわち、OCRコンポーネント1310は、ドキュメントサービス部130のOCR処理部131により、当該データ(データ型「LocalFilePath」)により示されるスキャン画像ファイルのOCR処理を行う。
Upon receiving the data from the type
そして、OCRコンポーネント1310は、処理結果を示すデータをフロー実行部301に返信する。なお、ここで返信されるデータは、OCRコンポーネント1310によりOCR処理されたスキャン画像ファイルを示すデータ(データ型「LocalFilePath」)である。
Then, the
次に、フロー実行部301は、処理フロー情報1100に基づいて、コンポーネントの取得要求をコンポーネント管理部302に送信する(ステップS1115)。すなわち、フロー実行部301は、図8に示す処理フロー情報1100の処理定義1103に定義されている「mail:send」を含むコンポーネントの取得要求をコンポーネント管理部302に送信する。
Next, the
コンポーネント管理部302は、コンポーネントの取得要求を受信すると、当該取得要求に含まれる「mail:send」に対応するメール配信コンポーネント1320を生成する(ステップS1116)。なお、メール配信コンポーネント1320の生成は、コンポーネント共通I/F1300を用いて行うことができる。
Upon receiving the component acquisition request, the
そして、コンポーネント管理部302は、生成したメール配信コンポーネント1320をフロー実行部301に返信する。すなわち、コンポーネント管理部302は、例えば、メール配信コンポーネント1320が展開されたメモリ(例えばRAM14)上のアドレスをフロー実行部301に返信する。
Then, the
フロー実行部301は、メール配信コンポーネント1320が返信されると、コンポーネントの処理実行要求を、当該メール配信コンポーネント1320に送信する(ステップS1117)。なお、コンポーネントの処理実行要求には、データと、パラメータとが含まれる。
When the
ここで、ステップS1117において、パラメータには、処理定義1103のオプションパラメータ「mail_address=null&filename=null」と、ユーザ指定情報とが含まれる。
Here, in step S1117, the parameters include the option parameter “mail_address = null & filename = null” of the
メール配信コンポーネント1320は、コンポーネントの処理実行要求を受信すると、型変換要求を型変換管理部304に送信する(ステップS1118)。なお、当該型変換要求には、データと、メール配信コンポーネント1320が扱うことができるデータ型を示す「LocalFilePath」の指定とが含まれる。
Upon receiving the component process execution request, the
型変換管理部304は、型変換要求を受信すると、当該型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致するか否かをチェックする(ステップS1119)。
Upon receiving the type conversion request, the type
ここで、型変換要求に含まれるデータのデータ型は「LocalFilePath」であり、指定されたデータ型も「LocalFilePath」である。したがって、型変換管理部304は、型変換要求に含まれるデータのデータ型と、指定されたデータ型とが一致するものと判断する。
Here, the data type of the data included in the type conversion request is “LocalFilePath”, and the designated data type is also “LocalFilePath”. Therefore, the type
すると、型変換管理部304は、型変換要求に含まれるデータをメール配信コンポーネント1320に送信する(ステップS1120)。このように、データ型のチェック(ステップS1118の処理)において、データのデータ型と、指定されたデータ型とが一致すると判断された場合には、型変換管理部304は、型変換の生成を行わない。
Then, the type
メール配信コンポーネント1320は、型変換管理部304からデータを受信すると、パラメータに基づいて、当該データに対して処理を実行する(ステップS1121)。すなわち、メール配信コンポーネント1320は、ドキュメントサービス部130のメール配信部132により、当該データにより示される電子ファイルを、パラメータに基づいて、メール配信する。
Upon receiving the data from the type
より具体的には、メール配信コンポーネント1320は、まず、パラメータに含まれるオプションパラメータにユーザ指定情報を定義して「mail_address=hoge@hogehoge.co.jp&filename=test.pdf」とする。次に、メール配信コンポーネント1320は、メール配信部132により、当該データにより示される電子ファイル(すなわち、OCR処理後のスキャン画像ファイル)のファイル名を「test.pdf」とした電子ファイルを添付したメールを作成する。最後に、メール配信コンポーネント1320は、メール配信部132により、作成したメールを「hoge@hogehoge.co.jp」宛に配信(送信)する。
More specifically, the
そして、メール配信コンポーネント1320は、処理結果を示すデータをフロー実行部301に返信する。なお、ここで返信されるデータは、例えば、メール配信コンポーネント1320により正常にメールが配信されたことを示す情報等である。
Then, the
フロー実行部201は、メール配信コンポーネント1320からデータを受信すると、ジョブ情報の更新要求をジョブ情報管理部401に送信する(ステップS1122)。なお、ジョブ情報の更新要求には、上記のステップS1102で返信されたジョブIDが含まれる。
Upon receiving the data from the
ジョブ情報管理部401は、ジョブ情報の更新要求を受信すると、ジョブ情報記憶部150に記憶されているジョブ情報のうち、当該更新要求に含まれるジョブIDのジョブ情報を更新する(ステップS1123)。すなわち、ジョブ情報管理部401は、当該ジョブIDのジョブ情報に含まれる状態を、「completed」に更新する。これにより、ジョブの実行が正常終了したことが管理される。
Upon receiving the job information update request, the job
以上のように、本実施形態に係るサービス提供システム10は、処理フロー情報1100に基づいて、各コンポーネントによる処理をそれぞれ行うことで、一連の処理(処理フロー)を実行する。これにより、本実施形態に係るサービス提供システム10は、当該一連の処理により実現されるサービスを提供することができる。
As described above, the
なお、例えば、一連の処理の実行中にエラー等が発生した場合、フロー実行部301は、ジョブ情報の更新要求をジョブ情報管理部401に送信して、ジョブ情報の状態を「error」に更新する。
Note that, for example, when an error or the like occurs during execution of a series of processes, the
以降では、クライアントアプリケーション210がジョブ情報を参照する場合について説明する。クライアントアプリケーション210は、ジョブ情報を参照することで、例えば、エラー原因の解析等を行うことができるようになる。
Hereinafter, a case where the
まず、ジョブ情報の参照が可能なアプリケーション(他のクライアントアプリケーションやアプリ情報1000)を登録する処理について、図13を参照しながら説明する。図13は、参照可能アプリケーションの登録処理の一例を示すシーケンス図である。 First, a process of registering an application (other client application or application information 1000) that can refer to job information will be described with reference to FIG. FIG. 13 is a sequence diagram illustrating an example of registration processing of a referenceable application.
まず、クライアントアプリケーション210は、参照可能アプリケーションの登録要求を認証サービス部120に送信する(ステップS1301)。このような登録要求は、例えば、ユーザが参照可能アプリケーションの登録操作を行うことにより送信することができる。
First, the
なお、参照可能アプリケーションの登録要求には、クライアントアプリケーション210のアプリIDと、ジョブ情報を参照することが可能なアプリケーションのアプリID(参照可能アプリID)と、テナントIDと、ユーザIDと、パスワードとが含まれる。
Note that the referenceable application registration request includes the application ID of the
認証サービス部120は、参照可能アプリケーションの登録要求を受信すると、当該登録要求に含まれるテナントID、ユーザID、及びパスワードに基づいて、ユーザ認証を行う(ステップS1302)。すなわち、認証サービス部120は、当該登録要求に含まれるテナントID、ユーザID、及びパスワードの組が、予め決められたテナントID、ユーザID、及びパスワードの組と一致するか否かを判定することで、ユーザ認証を行う。
Upon receiving the reference request registration request, the
そして、認証サービス部120は、ユーザ認証に成功した場合、参照可能アプリケーションの登録要求をアプリ管理部111に送信する(ステップS1303)。なお、参照可能アプリケーションの登録要求には、クライアントアプリケーション210のアプリIDと、参照可能アプリIDとが含まれる。
Then, when the user authentication is successful, the
アプリ管理部111は、参照可能アプリケーションの登録要求を受信すると、当該登録要求に含まれるアプリIDと参照可能IDとを関連付けた参照情報を作成し、参照情報記憶部160に記憶する(ステップS1304)。そして、アプリ管理部111は、登録結果をクライアントアプリケーション210に返信する。これにより、参照情報がサービス提供システム10に登録される。
Upon receiving the referenceable application registration request, the
ここで、参照情報記憶部160に記憶された参照情報について、図14を参照しながら説明する。図14は、参照情報の一例を示す図である。
Here, the reference information stored in the reference
図14に示すように、参照情報は、アプリIDと、参照可能アプリIDとを有する。アプリIDは、ジョブ情報の参照を行うアプリケーション(クライアントアプリケーション210又はアプリ情報1000)のアプリIDである。参照可能アプリIDは、ジョブ情報を参照することが可能な他のアプリケーション(クライアントアプリケーション210又はアプリ情報1000)のアプリIDである。
As shown in FIG. 14, the reference information has an application ID and a referenceable application ID. The application ID is the application ID of the application (the
このように、参照情報記憶部160に記憶されている参照情報には、アプリIDと、当該アプリIDのアプリケーションがジョブ情報を参照することができる他のアプリケーションのアプリIDとが関連付けられている。これにより、後述するように、クライアントアプリケーション210が、他のクライアントアプリケーション210又はアプリ情報1000のジョブ情報を参照する場合のアクセス制御を行うことができる。
In this way, the reference information stored in the reference
次に、クライアントアプリケーション210やアプリ情報1000等がジョブ情報を参照する場合の処理について、説明する。まず、認証サービス部120との間の認証方式が「アプリ認証」であるクライアントアプリケーション210がジョブ情報を参照する場合の処理について、図15を参照しながら説明する。図15は、ジョブ情報の参照処理の一例を示すシーケンス図である。
Next, a process when the
まず、クライアントアプリケーション210は、ジョブ情報の参照要求を認証サービス部120に送信する(ステップS1501)。このような参照要求は、例えば図16に示すジョブ情報の参照画面3100において、ユーザがジョブID入力欄3101にジョブIDを入力した上で、参照ボタン3102を押下することにより行うことができる。
First, the
なお、ジョブ情報の参照要求には、ジョブID入力欄3101に入力されたジョブIDと、クライアントシークレットとが含まれる。
The job information reference request includes the job ID input to the job
認証サービス部120は、ジョブ情報の参照要求を受信すると、当該参照要求に含まれるクライアントID及びクライアントシークレットに基づいて、アプリ認証を行う(ステップS1502)。すなわち、認証サービス部120は、当該参照要求に含まれるクライアントID及びクライアントシークレットの組が、予め決められたクライアントID及びクライアントシークレットの組と一致するか否かを判定することで、アプリ認証を行う。
Upon receiving the job information reference request, the
そして、認証サービス部120は、アプリ認証に成功した場合、ジョブ情報の参照要求をアクセス制御部402に送信する(ステップS1503)。なお、ジョブ情報の参照要求には、ジョブIDと、アプリIDとが含まれる。
Then, when the application authentication is successful, the
なお、認証サービス部120は、上記のステップS1502でアプリ認証に失敗した場合、例えば、アプリ認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
If the application authentication fails in step S1502 described above, the
アクセス制御部402は、ジョブ情報の参照要求を受信すると、ジョブ情報の取得要求をジョブ情報管理部401に送信する(ステップS1504)。なお、ジョブ情報の取得要求には、ジョブIDが含まれる。
Upon receiving the job information reference request, the
ジョブ情報管理部401は、ジョブ情報の取得要求を受信すると、当該取得要求に含まれるジョブIDのジョブ情報をジョブ情報記憶部150から取得する(ステップS1505)。例えば、ジョブ情報の取得要求に含まれるジョブIDが「ジョブ4」である場合、ジョブ情報管理部401は、ジョブID「ジョブ4」のジョブ情報をジョブ情報記憶部150から取得する。なお、ジョブ情報の取得要求に複数のジョブIDが含まれる場合、ジョブ情報管理部401は、複数のジョブ情報をジョブ情報記憶部150から取得する。
Upon receiving the job information acquisition request, the job
そして、ジョブ情報管理部401は、取得したジョブ情報をアクセス制御部402に返信する。
Then, the job
次に、アクセス制御部402は、アクセス権のチェックを行う(ステップS1506)。すなわち、アクセス制御部402は、ジョブ情報の参照要求に含まれるアプリIDと、上記のステップS1502で取得されたジョブ情報に含まれるアプリIDとが一致するか否かを判定する。
Next, the
そして、アクセス制御部402は、ジョブ情報の参照要求に含まれるアプリIDと、上記のステップS1502で取得されたジョブ情報に含まれるアプリIDとが一致すると判定した場合、ジョブ情報をクライアントアプリケーション210に返信する。
Then, when the
一方、アクセス制御部402は、これらのアプリIDが一致しないと判定した場合、参照可能アプリIDの取得要求をアプリ管理部111に送信する(ステップS1508)。なお、参照可能アプリIDの取得要求には、ジョブ情報の参照要求に含まれるアプリIDが含まれる。
On the other hand, when the
なお、上記のステップS1502で複数のジョブ情報が取得された場合、これらのジョブ情報のうち、上記のステップS1506でアプリIDが一致しないと判定されたジョブ情報について、ステップS1508以降の処理を行えば良い。 When a plurality of pieces of job information are acquired in step S1502, if the job information determined to have the same application ID in step S1506 among these pieces of job information is processed in step S1508 and subsequent steps, good.
次に、アプリ管理部111は、参照可能アプリIDの取得要求を受信すると、当該取得要求に含まれるアプリIDの参照情報を取得する(ステップS1508)。そして、アプリ管理部111は、取得した参照情報に含まれる参照可能アプリIDをアクセス制御部402に返信する。
Next, when receiving the referenceable application ID acquisition request, the
次に、アクセス制御部402は、アクセス権のチェックを行う(ステップS1509)。すなわち、アクセス制御部402は、上記のステップS1502で取得されたジョブ情報含まれるアプリIDと、参照可能アプリIDのうちの少なくとも一の参照可能アプリIDとが一致するか否かを判定する。
Next, the
そして、アクセス制御部402は、当該アプリIDと、参照可能アプリIDのうちの少なくとも一の参照可能アプリIDとが一致すると判定した場合、ジョブ情報をクライアントアプリケーション210に返信する。
Then, when the
一方、アクセス制御部402は、当該アプリIDと、全ての参照可能アプリIDとが一致しないと判定した場合、ジョブ情報の参照が許可されていないことを示す通知をクライアントアプリケーション210に返信する。したがって、この場合、クライアントアプリケーション210は、ジョブ情報を参照することができない。
On the other hand, when the
クライアントアプリケーション210は、アクセス制御部402からジョブ情報が返信された場合、例えば図16に示すジョブ情報の参照画面3100のジョブ情報欄3103にジョブ情報を表示する(ステップS1510)。これにより、クライアントアプリケーション210は、当該クライアントアプリケーション210のアプリIDが含まれるジョブ情報と、参照可能アプリIDが含まれるジョブ情報とを表示することができる。したがって、機器20のユーザは、クライアントアプリケーション210により表示されたジョブ情報を参照することで、例えば、エラーが発生したジョブのエラー原因解析等を行うことができるようになる。
When the job information is returned from the
このように、本実施形態に係る情報処理システム1では、機器20に搭載されたクライアントアプリケーション210がジョブ情報を参照する際に、当該ジョブ情報を参照する権限があるか否かを判定する。これにより、本実施形態に係る情報処理システム1では、サービス提供システム10は、参照権限があるジョブ情報に限り、クライアントアプリケーション210に表示させることができる。
As described above, in the
次に、認証サービス部120との間の認証方式が「ユーザ認証」であるクライアントアプリケーション210がジョブ情報を参照する場合の処理について、図17を参照しながら説明する。図17は、ジョブ情報の参照処理の他の例(その1)を示すシーケンス図である。
Next, a process when the
まず、クライアントアプリケーション210は、ジョブ情報の参照要求を認証サービス部120に送信する(ステップS1701)。なお、ジョブ情報の参照要求には、ジョブIDと、テナントIDと、ユーザIDと、パスワードとが含まれる。テナントID、ユーザID、及びパスワードは、例えば図16に示すジョブ情報の参照画面3100において、ユーザにより入力等されても良い。
First, the
認証サービス部120は、ジョブ情報の参照要求を受信すると、当該参照要求に含まれるテナントID、ユーザID、及びパスワードに基づいて、ユーザ認証を行う(ステップS1702)。すなわち、認証サービス部120は、当該参照要求に含まれるテナントID、ユーザID、及びパスワードの組が、予め決められたテナントID、ユーザID、及びパスワードの組と一致するか否かを判定することで、ユーザ認証を行う。
Upon receiving the job information reference request, the
そして、認証サービス部120は、ユーザ認証に成功した場合、ジョブ情報の参照要求をアクセス制御部402に送信する(ステップS1703)。なお、ジョブ情報の参照要求には、ジョブIDと、ユーザIDとが含まれる。
Then, if the user authentication is successful, the
なお、認証サービス部120は、上記のステップS1702でユーザ認証に失敗した場合、例えば、ユーザ認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
When the user authentication fails in step S1702 described above, the
アクセス制御部402は、ジョブ情報の参照要求を受信すると、ジョブ情報の取得要求をジョブ情報管理部401に送信する(ステップS1704)。なお、ジョブ情報の取得要求には、ジョブIDが含まれる。
Upon receiving the job information reference request, the
ジョブ情報管理部401は、ジョブ情報の取得要求を受信すると、当該取得要求に含まれるジョブIDのジョブ情報をジョブ情報記憶部150から取得する(ステップS1705)。そして、ジョブ情報管理部401は、取得したジョブ情報をアクセス制御部402に返信する。
Upon receiving the job information acquisition request, the job
次に、アクセス制御部402は、アクセス権のチェックを行う(ステップS1706)。すなわち、アクセス制御部402は、ジョブ情報の参照要求に含まれるユーザIDと、上記のステップS1702で取得されたジョブ情報に含まれるユーザIDとが一致するか否かを判定する。
Next, the
そして、アクセス制御部402は、ジョブ情報の参照要求に含まれるユーザIDと、上記のステップS1702で取得されたジョブ情報に含まれるユーザIDとが一致すると判定した場合、ジョブ情報をクライアントアプリケーション210に返信する。
If the
一方、アクセス制御部402は、これらのユーザIDが一致しないと判定した場合、ジョブ情報の参照が許可されていないことを示す通知をクライアントアプリケーション210に返信する。したがって、この場合、クライアントアプリケーション210は、ジョブ情報を参照することができない。
On the other hand, when the
クライアントアプリケーション210は、アクセス制御部402からジョブ情報が返信された場合、ジョブ情報を表示する(ステップS1707)。これにより、クライアントアプリケーション210は、機器20のユーザのユーザIDが含まれるジョブ情報を表示することができる。
When the job information is returned from the
なお、図17では、クライアントアプリケーション210と認証サービス部120との間の認証方式が「ユーザ認証」である場合について説明したが、ステップS1703以降は、当該認証方式が「アクセストークン認証」である場合も同様に適用することができる。なお、この場合、ステップS1701のジョブ情報の参照要求には、ジョブIDと、アクセストークンとが含まれる点、及びステップS1702でアクセストークン認証を行う点が図17と異なる。
Note that, although the case where the authentication method between the
ここで、図12に示すように、ジョブ情報記憶部150に記憶されているジョブ情報には、ユーザIDが含まれているが、ユーザIDに代えて(又はユーザIDに加えて)、テナントIDが含まれていても良い。すなわち、例えば、図18に示すように、ジョブ情報記憶部150に記憶されているジョブ情報には、ユーザIDに代えて、テナントIDが含まれていても良い。
Here, as shown in FIG. 12, the job information stored in the job
この場合において、認証サービス部120との間の認証方式が「ユーザ認証」であるクライアントアプリケーション210がジョブ情報を参照する場合の処理について、図19を参照しながら説明する。図19は、ジョブ情報の参照処理の他の例(その2)を示すシーケンス図である。
In this case, a process when the
まず、クライアントアプリケーション210は、ジョブ情報の参照要求を認証サービス部120に送信する(ステップS1901)。なお、ジョブ情報の参照要求には、ジョブIDと、テナントIDと、ユーザIDと、パスワードとが含まれる。テナントID、ユーザID、及びパスワードは、例えば図16に示すジョブ情報の参照画面3100において、ユーザにより入力等されても良い。
First, the
認証サービス部120は、ジョブ情報の参照要求を受信すると、当該参照要求に含まれるテナントID、ユーザID、及びパスワードに基づいて、ユーザ認証を行う(ステップS1902)。すなわち、認証サービス部120は、当該参照要求に含まれるテナントID、ユーザID、及びパスワードの組が、予め決められたテナントID、ユーザID、及びパスワードの組と一致するか否かを判定することで、ユーザ認証を行う。
Upon receipt of the job information reference request, the
そして、認証サービス部120は、ユーザ認証に成功した場合、ジョブ情報の参照要求をアクセス制御部402に送信する(ステップS1903)。なお、ジョブ情報の参照要求には、ジョブIDと、テナントIDとが含まれる。
Then, when the user authentication is successful, the
なお、認証サービス部120は、上記のステップS1702でユーザ認証に失敗した場合、例えば、ユーザ認証に失敗したことを示す通知をクライアントアプリケーション210に返信する。
When the user authentication fails in step S1702 described above, the
アクセス制御部402は、ジョブ情報の参照要求を受信すると、ジョブ情報の取得要求をジョブ情報管理部401に送信する(ステップS1904)。なお、ジョブ情報の取得要求には、ジョブIDが含まれる。
Upon receiving the job information reference request, the
ジョブ情報管理部401は、ジョブ情報の取得要求を受信すると、当該取得要求に含まれるジョブIDのジョブ情報をジョブ情報記憶部150から取得する(ステップS1905)。そして、ジョブ情報管理部401は、取得したジョブ情報をアクセス制御部402に返信する。
Upon receiving the job information acquisition request, the job
次に、アクセス制御部402は、アクセス権のチェックを行う(ステップS1906)。すなわち、アクセス制御部402は、ジョブ情報の参照要求に含まれるテナントIDと、上記のステップS1902で取得されたジョブ情報に含まれるテナントIDとが一致するか否かを判定する。
Next, the
そして、アクセス制御部402は、ジョブ情報の参照要求に含まれるテナントIDと、上記のステップS1902で取得されたジョブ情報に含まれるテナントIDとが一致すると判定した場合、ジョブ情報をクライアントアプリケーション210に返信する。
Then, when the
一方、アクセス制御部402は、これらのテナントIDが一致しないと判定した場合、ジョブ情報の参照が許可されていないことを示す通知をクライアントアプリケーション210に返信する。したがって、この場合、クライアントアプリケーション210は、ジョブ情報を参照することができない。
On the other hand, when the
クライアントアプリケーション210は、アクセス制御部402からジョブ情報が返信された場合、ジョブ情報を表示する(ステップS1907)。これにより、クライアントアプリケーション210は、機器20のユーザのテナントIDが含まれるジョブ情報を表示することができる。
When the job information is returned from the
<まとめ>
以上のように、本実施形態に係る情報処理システム1は、クライアントアプリケーション210が、サービスを実現する一連の処理を実行させる際に、当該クライアントアプリケーション210の認証を行う。しかも、本実施形態に係る情報処理システム1では、クライアントアプリケーション210に応じて、様々な認証方式により認証を行うことができる。
<Summary>
As described above, the
したがって、本実施形態に係る情報処理システム1では、正当なユーザ(クライアントアプリケーション210や機器20のユーザ)に限り、サービス提供システム10が提供するサービスを利用させるようにすることができる。
Therefore, in the
また、本実施形態に係る情報処理システム1では、クライアントアプリケーション210等が、他のアプリケーション(他のクライアントアプリケーション210やアプリ情報1000等)により実行された一連の処理のジョブ情報を参照することができる。しかも、本実施形態に係る情報処理システム1では、クライアントアプリケーション210等がジョブ情報を参照するための権限を有しているか否かを判定することで、アクセス制御を行う。これにより、本実施形態に係る情報処理システム1では、正当なユーザ(クライアントアプリケーション210やアプリ情報1000等)に限り、ジョブ情報の参照を許可することができる。
Further, in the
本発明は、具体的に開示された上記の実施形態に限定されるものではなく、特許請求の範囲から逸脱することなく、種々の変形や変更が可能である。 The present invention is not limited to the above specifically disclosed embodiments, and various modifications and changes can be made without departing from the scope of the claims.
1 情報処理システム
10 サービス提供システム
20 機器
110 入出力サービス処理部
111 アプリ管理部
112 ロジック処理部
113 ジョブ管理部
120 認証サービス部
130 ドキュメントサービス部
140 アプリ情報記憶部
150 ジョブ情報記憶部
160 参照情報記憶部
210 クライアントアプリケーション
301 フロー実行部
302 コンポーネント管理部
303 コンポーネント群
304 型変換管理部
305 型変換群
401 ジョブ情報管理部
402 アクセス制御部
DESCRIPTION OF
Claims (9)
電子データを用いた一連の処理毎に、該一連の処理のそれぞれの処理を実行する1以上の前記プログラムを識別するプログラム識別情報と、1以上の前記プログラムの実行順とが定義されたフロー情報を、該フロー情報を識別するフロー識別情報と関連付けて記憶する記憶手段と、
前記情報処理システムに接続される1以上の機器のうちの一の機器から、電子データに関する情報と、前記フロー識別情報と、前記一の機器の認証を行うための認証情報とを含む第1の要求を受信する第1の受信手段と、
前記第1の受信手段により受信された前記第1の要求に含まれる前記認証情報に基づいて、前記一の機器の認証を行う認証手段と、
前記認証手段による前記認証が成功した場合、前記記憶手段に記憶されているフロー情報のうち、前記第1の受信手段により受信された前記第1の要求に含まれる前記フロー識別情報と関連付けて前記記憶手段に記憶されている前記フロー情報を取得する取得手段と、
前記取得手段により取得された前記フロー情報に定義されている前記プログラム識別情報に識別されるプログラムそれぞれを、前記フロー情報に定義されている前記実行順に従って実行させることで、前記第1の受信手段により受信された前記第1の要求に含まれる前記電子データに関する情報に基づく電子データを用いた前記一連の処理を実行する実行手段と、
を有する情報処理システム。 An information processing system including a plurality of programs, each of which includes one or more information processing devices and executes a predetermined process,
Flow information in which, for each series of processing using electronic data, program identification information for identifying one or more programs for executing respective processing of the series of processing and execution order of the one or more programs are defined. And a storage unit that stores the flow information in association with the flow identification information for identifying the flow information,
A first device including information about electronic data, the flow identification information, and authentication information for authenticating the one device from one device of one or more devices connected to the information processing system. First receiving means for receiving the request;
Authentication means for authenticating the one device based on the authentication information included in the first request received by the first receiving means;
When the authentication by the authentication unit is successful, the flow information stored in the storage unit is associated with the flow identification information included in the first request received by the first receiving unit, and is associated with the flow identification information. Acquisition means for acquiring the flow information stored in the storage means,
By executing each of the programs identified by the program identification information defined in the flow information acquired by the acquisition means according to the execution order defined in the flow information, the first reception means Executing means for executing the series of processes using electronic data based on information about the electronic data included in the first request received by
Information processing system having.
前記一の機器に搭載され、前記第1の要求を送信するアプリケーションプログラムを識別するアプリ識別情報と、該アプリ識別情報に対する第1のパスワードとを含み、
前記認証手段は、
前記認証情報に含まれる前記アプリ識別情報と、前記第1のパスワードとに基づいて、前記一の機器の認証を行う、請求項1に記載の情報処理システム。 The authentication information is
The application identification information, which is installed in the one device and identifies the application program that transmits the first request, and a first password for the application identification information,
The authentication means is
The information processing system according to claim 1, wherein authentication of the one device is performed based on the application identification information included in the authentication information and the first password.
前記一の機器を利用するユーザを識別するユーザ識別情報と、該ユーザが属するグループを識別するグループ識別情報と、前記ユーザ識別情報及び前記グループ識別情報に対する第2のパスワードとを含み、
前記認証手段は、
前記認証情報に含まれる前記ユーザ識別情報と、前記グループ識別情報と、前記第2のパスワードとに基づいて、前記一の機器の認証を行う、請求項1に記載の情報処理システム。 The authentication information is
Including user identification information for identifying a user who uses the one device, group identification information for identifying a group to which the user belongs, and a second password for the user identification information and the group identification information,
The authentication means is
The information processing system according to claim 1, wherein authentication of the one device is performed based on the user identification information included in the authentication information, the group identification information, and the second password.
OAuthによるアクセストークンを含み、
前記認証手段は、
前記認証情報に含まれるアクセストークンに基づいて、前記一の機器の認証を行う、請求項1に記載の情報処理システム。 The authentication information is
Including an access token by OAuth,
The authentication means is
The information processing system according to claim 1, wherein the one device is authenticated based on an access token included in the authentication information.
前記情報処理システムに接続される1以上の機器のうちの一の機器から、前記ジョブ識別情報と、前記認証情報とを含む第2の要求を受信する第2の受信手段と、
前記第2の受信手段により受信された前記第2の要求に含まれる前記ジョブ識別情報の前記ジョブ情報を取得するジョブ情報取得手段と、
前記ジョブ情報取得手段により取得された前記ジョブ情報を、前記第2の要求の要求元の前記一の機器に送信する送信手段と、を有し、
前記認証手段は、
前記第2の受信手段により受信された前記第2の要求に含まれる前記認証情報に基づいて、前記一の機器の認証を行い、
前記ジョブ情報取得手段は、
前記認証手段による前記認証が成功した場合、前記第2の受信手段により受信された前記第2の要求に含まれる前記ジョブ識別情報の前記ジョブ情報を取得する、請求項1乃至4の何れか一項に記載の情報処理システム。 A job information storage unit that stores job information including the job identification information of the job indicating the series of processes and the execution state of the job;
Second receiving means for receiving a second request including the job identification information and the authentication information from one of the one or more devices connected to the information processing system;
Job information acquisition means for acquiring the job information of the job identification information included in the second request received by the second reception means;
Transmission means for transmitting the job information acquired by the job information acquisition means to the one device that is the request source of the second request,
The authentication means is
Authenticating the one device based on the authentication information included in the second request received by the second receiving means;
The job information acquisition means,
The job information of the job identification information included in the second request received by the second receiving unit is acquired when the authentication by the authenticating unit is successful. Information processing system according to item.
前記第2の受信手段は、
前記情報処理システムに接続される1以上の機器のうちの一の機器から、前記ジョブ識別情報と、前記認証情報と、前記一の機器に搭載されたアプリケーションプログラムを識別する第2のアプリ識別情報を含む第2の要求を受信し、
前記送信手段は、
前記ジョブ情報取得手段により取得された前記ジョブ情報に含まれる前記第1のアプリ識別情報と、前記第2の要求に含まれる前記第2のアプリ識別情報とが一致する場合、前記ジョブ情報を、前記第2の要求の要求元の前記一の機器に送信する、請求項5に記載の情報処理システム。 The job information further includes first application identification information for identifying an application program that has executed the series of processes among application programs installed in one or more devices connected to the information processing system. Included,
The second receiving means is
Second application identification information for identifying the job identification information, the authentication information, and an application program installed in the one device from one of the one or more devices connected to the information processing system Receiving a second request containing
The transmitting means is
When the first application identification information included in the job information acquired by the job information acquisition unit and the second application identification information included in the second request match, the job information, The information processing system according to claim 5, wherein the information is transmitted to the one device that is a request source of the second request.
前記送信手段は、
前記ジョブ情報取得手段により取得された前記ジョブ情報に含まれる前記第1のアプリ識別情報と、前記第2の要求に含まれる前記第2のアプリ識別情報とが一致する場合、又は、前記第1のアプリ識別情報と、前記第2のアプリ識別情報に対応する前記参照情報に含まれる前記参照可能アプリ識別情報とが一致する場合、前記ジョブ情報を、前記第2の要求の要求元の前記一の機器に送信する、請求項6に記載の情報処理システム。 A reference for storing reference information including application identification information for identifying an application program installed in the device and referenceable application identification information for identifying another application program with which the application program can refer to the job information. Has information storage means,
The transmitting means is
When the first application identification information included in the job information acquired by the job information acquisition unit and the second application identification information included in the second request match, or the first application identification information And the referenceable application identification information included in the reference information corresponding to the second application identification information are matched, the job information is set to the one of the request source of the second request. The information processing system according to claim 6, which is transmitted to the device.
電子データを用いた一連の処理毎に、該一連の処理のそれぞれの処理を実行する1以上の前記プログラムを識別するプログラム識別情報と、1以上の前記プログラムの実行順とが定義されたフロー情報を、該フロー情報を識別するフロー識別情報と関連付けて記憶する記憶手段と、
前記情報処理装置に接続される1以上の機器のうちの一の機器から、電子データに関する情報と、前記フロー識別情報と、前記一の機器の認証を行うための認証情報とを含む第1の要求を受信する第1の受信手段と、
前記第1の受信手段により受信された前記第1の要求に含まれる前記認証情報に基づいて、前記一の機器の認証を行う認証手段と、
前記認証手段による前記認証が成功した場合、前記記憶手段に記憶されているフロー情報のうち、前記第1の受信手段により受信された前記第1の要求に含まれる前記フロー識別情報と関連付けて前記記憶手段に記憶されている前記フロー情報を取得する取得手段と、
前記取得手段により取得された前記フロー情報に定義されている前記プログラム識別情報に識別されるプログラムそれぞれを、前記フロー情報に定義されている前記実行順に従って実行させることで、前記第1の受信手段により受信された前記第1の要求に含まれる前記電子データに関する情報に基づく電子データを用いた前記一連の処理を実行する実行手段と、
を有する情報処理装置。 An information processing apparatus having a plurality of programs that respectively execute predetermined processes,
Flow information in which, for each series of processing using electronic data, program identification information for identifying one or more programs for executing respective processing of the series of processing and execution order of the one or more programs are defined. And a storage unit that stores the flow information in association with the flow identification information for identifying the flow information,
A first device including information related to electronic data, the flow identification information, and authentication information for authenticating the one device from one of the one or more devices connected to the information processing apparatus. First receiving means for receiving the request;
Authentication means for authenticating the one device based on the authentication information included in the first request received by the first receiving means;
When the authentication by the authentication unit is successful, the flow information stored in the storage unit is associated with the flow identification information included in the first request received by the first receiving unit, and is associated with the flow identification information. Acquisition means for acquiring the flow information stored in the storage means,
By executing each of the programs identified by the program identification information defined in the flow information acquired by the acquisition means according to the execution order defined in the flow information, the first reception means Executing means for executing the series of processes using electronic data based on information about the electronic data included in the first request received by
Information processing device having a.
前記情報処理システムに接続される1以上の機器のうちの一の機器から、電子データに関する情報と、前記フロー識別情報と、前記一の機器の認証を行うための認証情報とを含む第1の要求を受信する第1の受信手順と、
前記第1の受信手順により受信された前記第1の要求に含まれる前記認証情報に基づいて、前記一の機器の認証を行う認証手順と、
前記認証手順による前記認証が成功した場合、前記記憶手段に記憶されているフロー情報のうち、前記第1の受信手順により受信された前記第1の要求に含まれる前記フロー識別情報と関連付けて前記記憶手段に記憶されている前記フロー情報を取得する取得手順と、
前記取得手順により取得された前記フロー情報に定義されている前記プログラム識別情報に識別されるプログラムそれぞれを、前記フロー情報に定義されている前記実行順に従って実行させることで、前記第1の受信手順により受信された前記第1の要求に含まれる前記電子データに関する情報に基づく電子データを用いた前記一連の処理を実行する実行手順と、
を有する情報処理方法。 An information processing method used in an information processing system including a plurality of programs each including one or more information processing devices, the programs each executing a predetermined process, wherein each of the series of processes using electronic data Program identification information that identifies one or more programs that execute respective processes and flow information that defines the execution order of one or more programs are stored in association with the flow identification information that identifies the flow information. In an information processing system having storage means,
A first device including information about electronic data, the flow identification information, and authentication information for authenticating the one device from one device of one or more devices connected to the information processing system. A first receiving procedure for receiving the request,
An authentication procedure for authenticating the one device based on the authentication information included in the first request received by the first reception procedure;
When the authentication by the authentication procedure is successful, the flow information stored in the storage means is associated with the flow identification information included in the first request received by the first receiving procedure, An acquisition procedure for acquiring the flow information stored in the storage means,
By executing each of the programs identified by the program identification information defined in the flow information acquired by the acquisition procedure according to the execution order defined in the flow information, the first reception procedure An execution procedure for executing the series of processes using electronic data based on information about the electronic data included in the first request received by
Information processing method having.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2016128645A JP6696326B2 (en) | 2016-06-29 | 2016-06-29 | Information processing system, information processing apparatus, and information processing method |
JP2020076892A JP6981497B2 (en) | 2016-06-29 | 2020-04-23 | Information processing system, information processing device, and information processing method |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2016128645A JP6696326B2 (en) | 2016-06-29 | 2016-06-29 | Information processing system, information processing apparatus, and information processing method |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2020076892A Division JP6981497B2 (en) | 2016-06-29 | 2020-04-23 | Information processing system, information processing device, and information processing method |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2018005379A JP2018005379A (en) | 2018-01-11 |
JP6696326B2 true JP6696326B2 (en) | 2020-05-20 |
Family
ID=60949268
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2016128645A Active JP6696326B2 (en) | 2016-06-29 | 2016-06-29 | Information processing system, information processing apparatus, and information processing method |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP6696326B2 (en) |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4265262B2 (en) * | 2003-04-08 | 2009-05-20 | 富士ゼロックス株式会社 | Printing system, printing request terminal and printing control method |
JP5602059B2 (en) * | 2011-02-28 | 2014-10-08 | 京セラドキュメントソリューションズ株式会社 | Mobile printing system |
JP6094152B2 (en) * | 2012-11-08 | 2017-03-15 | 株式会社リコー | Information processing apparatus, information processing system, information processing method, and program |
JP2015032043A (en) * | 2013-07-31 | 2015-02-16 | 株式会社リコー | Service providing system, service providing method, and program |
JP6390123B2 (en) * | 2014-03-11 | 2018-09-19 | 株式会社リコー | Information processing system and authentication information providing method |
JP6233148B2 (en) * | 2014-03-31 | 2017-11-22 | 京セラドキュメントソリューションズ株式会社 | Image forming system, server, image forming apparatus, terminal, image forming method, and program |
-
2016
- 2016-06-29 JP JP2016128645A patent/JP6696326B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
JP2018005379A (en) | 2018-01-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9608972B2 (en) | Service providing system and data providing method that convert a process target data into output data with a data format that a service receiving apparatus is able to output | |
EP2950230B1 (en) | Information processing system, method of processing information, information processing apparatus, and program | |
US9537849B2 (en) | Service provision system, service provision method, and computer program product | |
US20140129607A1 (en) | Information processing apparatus, information processing system, and information processing method | |
JP2014081779A (en) | Device management system, peripheral device, and control method therefor | |
US20120096465A1 (en) | Image forming apparatus, log management method, and storage medium | |
US10530943B2 (en) | Information processing system configured to maintain application state information associated with an application, information processing apparatus, and information processing method | |
JP4958118B2 (en) | Image forming apparatus, information processing system, processing method thereof, and program | |
JP2018022295A (en) | Information processing apparatus and application management method, and program | |
JP6772578B2 (en) | Information processing system, information processing device, and information processing method | |
US20150040189A1 (en) | Service provision system, service provision method, and computer program product | |
JP7146422B2 (en) | Information processing device and cookie information management method | |
US20190289157A1 (en) | Information processing system, information processing method and non-transitory computer-readable storage medium | |
US20150081834A1 (en) | Information processing system and method | |
JP6981497B2 (en) | Information processing system, information processing device, and information processing method | |
JP6696326B2 (en) | Information processing system, information processing apparatus, and information processing method | |
JP6780364B2 (en) | Information processing system, information processing device, and information processing method | |
EP4068073A1 (en) | System, printing system, and control method | |
US11645027B2 (en) | Information processing system and method for processing data output requests and identification information | |
JP2011029848A (en) | Image forming device, information processing method, and program therefor | |
US10649703B2 (en) | Print control apparatus, control method of a print control apparatus, and recording medium | |
JP2020123978A (en) | Information processing system, information processing device, information processing method, and program | |
JP5376546B2 (en) | Image forming apparatus, information processing system, processing method thereof, and program | |
JP7490471B2 (en) | Image processing device and method | |
JP2015032041A (en) | Service providing system, service providing method, and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20190403 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20200228 |
|
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: 20200324 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20200406 |
|
R151 | Written notification of patent or utility model registration |
Ref document number: 6696326 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R151 |